summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorJulien Veyssier <eneiluj@posteo.net>2021-04-01 11:42:39 +0200
committerJulien Veyssier <eneiluj@posteo.net>2021-04-01 11:55:13 +0200
commit7b6989747463773dcd4d3bba3854b8e713a1d214 (patch)
treede58242c7e111a1199403630745083e8a9c420fa /core
parent68d364007691750a5e8ec218c87e6cd8b0919245 (diff)
downloadnextcloud-server-7b6989747463773dcd4d3bba3854b8e713a1d214.tar.gz
nextcloud-server-7b6989747463773dcd4d3bba3854b8e713a1d214.zip
show informative errors in log and UI on avatar upload error in user settings
Signed-off-by: Julien Veyssier <eneiluj@posteo.net>
Diffstat (limited to 'core')
-rw-r--r--core/Controller/AvatarController.php14
1 files changed, 13 insertions, 1 deletions
diff --git a/core/Controller/AvatarController.php b/core/Controller/AvatarController.php
index 69ec2f4bffe..34815321495 100644
--- a/core/Controller/AvatarController.php
+++ b/core/Controller/AvatarController.php
@@ -193,8 +193,20 @@ class AvatarController extends Controller {
$content = $this->cache->get('avatar_upload');
unlink($files['tmp_name'][0]);
} else {
+ $phpFileUploadErrors = [
+ UPLOAD_ERR_OK => $this->l->t('The file was uploaded'),
+ UPLOAD_ERR_INI_SIZE => $this->l->t('The uploaded file exceeds the upload_max_filesize directive in php.ini'),
+ UPLOAD_ERR_FORM_SIZE => $this->l->t('The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form'),
+ UPLOAD_ERR_PARTIAL => $this->l->t('The file was only partially uploaded'),
+ UPLOAD_ERR_NO_FILE => $this->l->t('No file was uploaded'),
+ UPLOAD_ERR_NO_TMP_DIR => $this->l->t('Missing a temporary folder'),
+ UPLOAD_ERR_CANT_WRITE => $this->l->t('Could not write file to disk'),
+ UPLOAD_ERR_EXTENSION => $this->l->t('A PHP extension stopped the file upload'),
+ ];
+ $message = $phpFileUploadErrors[$files['error'][0]] ?? $this->l->t('Invalid file provided');
+ $this->logger->warning($message, ['app' => 'core']);
return new JSONResponse(
- ['data' => ['message' => $this->l->t('Invalid file provided')]],
+ ['data' => ['message' => $message]],
Http::STATUS_BAD_REQUEST
);
}