Browse Source

Merge pull request #16021 from nextcloud/bugfix/noid/fall-back-to-black-for-non-color-values

Fall back to black for non-color values
Roeland Jago Douma 4 years ago
parent
commit
a47403d5f8
2 changed files with 6 additions and 0 deletions
  1. 1 0
      core/Controller/SvgController.php
  2. 5 0
      lib/private/Template/IconsCacher.php

+ 1 - 0
core/Controller/SvgController.php

@@ -111,6 +111,7 @@ class SvgController extends Controller {
 	 *
 	 * @param string $path
 	 * @param string $color
+	 * @param string $fileName
 	 * @return DataDisplayResponse|NotFoundResponse
 	 */
 	private function getSvg(string $path, string $color, string $fileName) {

+ 5 - 0
lib/private/Template/IconsCacher.php

@@ -184,6 +184,11 @@ class IconsCacher {
 	 * @return string
 	 */
 	public function colorizeSvg($svg, $color): string {
+		if (!preg_match('/^[0-9a-f]{3,6}$/i', $color)) {
+			// Prevent not-sane colors from being written into the SVG
+			$color = '000';
+		}
+
 		// add fill (fill is not present on black elements)
 		$fillRe = '/<((circle|rect|path)((?!fill)[a-z0-9 =".\-#():;,])+)\/>/mi';
 		$svg = preg_replace($fillRe, '<$1 fill="#' . $color . '"/>', $svg);