diff --git a/lib/models/Courseware/BlockTypes/Text.php b/lib/models/Courseware/BlockTypes/Text.php index b72801945e69f7c8fc37a7538b25eaeb6e5991be..8d8cb45b30e5e315c2ebf3993ba10ef1b6c6a69c 100644 --- a/lib/models/Courseware/BlockTypes/Text.php +++ b/lib/models/Courseware/BlockTypes/Text.php @@ -48,17 +48,19 @@ class Text extends BlockType { $document = new \DOMDocument(); $old_libxml_error = libxml_use_internal_errors(true); - $document->loadHTML($payload['text']); - libxml_use_internal_errors($old_libxml_error); - $imageElements = $document->getElementsByTagName('img'); - foreach ($imageElements as $element) { - if (!$element instanceof \DOMElement || !$element->hasAttribute('src')) { - continue; - } - $src = $element->getAttribute('src'); - if (str_contains($src, 'sendfile.php') && !str_contains($src, $GLOBALS['ABSOLUTE_URI_STUDIP'])) { - $find = explode('sendfile.php', $src)[0]; - $payload['text'] = str_replace($find, $GLOBALS['ABSOLUTE_URI_STUDIP'], $payload['text']); + if (!empty($payload['text'])) { + $document->loadHTML($payload['text']); + libxml_use_internal_errors($old_libxml_error); + $imageElements = $document->getElementsByTagName('img'); + foreach ($imageElements as $element) { + if (!$element instanceof \DOMElement || !$element->hasAttribute('src')) { + continue; + } + $src = $element->getAttribute('src'); + if (str_contains($src, 'sendfile.php') && !str_contains($src, $GLOBALS['ABSOLUTE_URI_STUDIP'])) { + $find = explode('sendfile.php', $src)[0]; + $payload['text'] = str_replace($find, $GLOBALS['ABSOLUTE_URI_STUDIP'], $payload['text']); + } } } $payload['text'] = \Studip\Markup::purifyHtml(\Studip\Markup::markAsHtml($payload['text']));