mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
FIX Make ShortcodeParser#parse passthrough not error on invalid HTML
This commit is contained in:
parent
5bbf94d2f4
commit
cbef44b8d6
@ -456,6 +456,31 @@ class ShortcodeParser {
|
|||||||
$this->removeNode($node);
|
$this->removeNode($node);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function loadHTML($html) {
|
||||||
|
require_once(THIRDPARTY_PATH.'/html5lib/HTML5/Parser.php');
|
||||||
|
|
||||||
|
// Convert any errors to exceptions
|
||||||
|
set_error_handler(
|
||||||
|
function($no, $str){
|
||||||
|
throw new Exception("HTML Parse Error: ".$str);
|
||||||
|
},
|
||||||
|
error_reporting()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Use HTML5lib to parse the HTML fragment
|
||||||
|
try {
|
||||||
|
$bases = HTML5_Parser::parseFragment(trim($html), 'div');
|
||||||
|
}
|
||||||
|
catch (Exception $e) {
|
||||||
|
$bases = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disable our error handler (restoring to previous value)
|
||||||
|
restore_error_handler();
|
||||||
|
|
||||||
|
return $bases;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parse a string, and replace any registered shortcodes within it with the result of the mapped callback.
|
* Parse a string, and replace any registered shortcodes within it with the result of the mapped callback.
|
||||||
*
|
*
|
||||||
@ -474,9 +499,8 @@ class ShortcodeParser {
|
|||||||
list($content, $tags) = $this->replaceElementTagsWithMarkers($content);
|
list($content, $tags) = $this->replaceElementTagsWithMarkers($content);
|
||||||
|
|
||||||
// Now parse the result into a DOM
|
// Now parse the result into a DOM
|
||||||
require_once(THIRDPARTY_PATH.'/html5lib/HTML5/Parser.php');
|
$bases = $this->loadHTML($content);
|
||||||
$bases = HTML5_Parser::parseFragment(trim($content), 'div');
|
|
||||||
|
|
||||||
// If we couldn't parse the HTML, error out
|
// If we couldn't parse the HTML, error out
|
||||||
if (!$bases || !$bases->length) {
|
if (!$bases || !$bases->length) {
|
||||||
if(self::$error_behavior == self::ERROR) {
|
if(self::$error_behavior == self::ERROR) {
|
||||||
@ -488,8 +512,8 @@ class ShortcodeParser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$res = '';
|
$res = '';
|
||||||
$html = $bases->item(0)->parentNode;
|
$container = $bases->item(0)->parentNode;
|
||||||
$doc = $html->ownerDocument;
|
$doc = $container->ownerDocument;
|
||||||
|
|
||||||
$xp = new DOMXPath($doc);
|
$xp = new DOMXPath($doc);
|
||||||
|
|
||||||
@ -526,7 +550,7 @@ class ShortcodeParser {
|
|||||||
$this->replaceMarkerWithContent($shortcode, $tag);
|
$this->replaceMarkerWithContent($shortcode, $tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach($html->childNodes as $child) $res .= $doc->saveHTML($child);
|
foreach($container->childNodes as $child) $res .= $doc->saveHTML($child);
|
||||||
|
|
||||||
return $res;
|
return $res;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user