Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Weimann <mail@michael-weimann.eu>2018-09-02 15:17:17 +0300
committerRoeland Jago Douma <roeland@famdouma.nl>2018-09-05 21:50:21 +0300
commit38ea5d14b38d86fe09acf0df34857c9eba6e1c6f (patch)
treea598a2f6c5ecfacefcdf0c4fc9ae640925558cd7 /apps/theming/lib/Controller
parent0899f2cbc43b05005dc045db001c41e199192f67 (diff)
Disables SVG favicon uploads when imagemagick is missing.
Signed-off-by: Michael Weimann <mail@michael-weimann.eu>
Diffstat (limited to 'apps/theming/lib/Controller')
-rw-r--r--apps/theming/lib/Controller/IconController.php2
-rw-r--r--apps/theming/lib/Controller/ThemingController.php20
2 files changed, 20 insertions, 2 deletions
diff --git a/apps/theming/lib/Controller/IconController.php b/apps/theming/lib/Controller/IconController.php
index a2727546e09..bffabf43dd7 100644
--- a/apps/theming/lib/Controller/IconController.php
+++ b/apps/theming/lib/Controller/IconController.php
@@ -115,7 +115,7 @@ class IconController extends Controller {
$response = null;
$iconFile = null;
try {
- $iconFile = $this->imageManager->getImage('favicon');
+ $iconFile = $this->imageManager->getImage('favicon', false);
$response = new FileDisplayResponse($iconFile, Http::STATUS_OK, ['Content-Type' => 'image/x-icon']);
} catch (NotFoundException $e) {
}
diff --git a/apps/theming/lib/Controller/ThemingController.php b/apps/theming/lib/Controller/ThemingController.php
index 44f1ea51c06..a1fa5e57836 100644
--- a/apps/theming/lib/Controller/ThemingController.php
+++ b/apps/theming/lib/Controller/ThemingController.php
@@ -265,7 +265,7 @@ class ThemingController extends Controller {
$this->imageManager->delete($key);
$target = $folder->newFile($key);
- $supportedFormats = ['image/jpeg', 'image/png', 'image/gif', 'image/svg+xml', 'image/svg'];
+ $supportedFormats = $this->getSupportedUploadImageFormats($key);
$detectedMimeType = mime_content_type($image['tmp_name']);
if (!in_array($image['type'], $supportedFormats) || !in_array($detectedMimeType, $supportedFormats)) {
return new DataResponse(
@@ -319,6 +319,24 @@ class ThemingController extends Controller {
}
/**
+ * Returns a list of supported mime types for image uploads.
+ * "favicon" images are only allowed to be SVG when imagemagick with SVG support is available.
+ *
+ * @param string $key The image key, e.g. "favicon"
+ * @return array
+ */
+ private function getSupportedUploadImageFormats(string $key): array {
+ $supportedFormats = ['image/jpeg', 'image/png', 'image/gif',];
+
+ if ($key !== 'favicon' || $this->imageManager->shouldReplaceIcons() === true) {
+ $supportedFormats[] = 'image/svg+xml';
+ $supportedFormats[] = 'image/svg';
+ }
+
+ return $supportedFormats;
+ }
+
+ /**
* Revert setting to default value
*
* @param string $setting setting which should be reverted