aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkondou <kondou@ts.unde.re>2013-09-01 19:12:54 +0200
committerkondou <kondou@ts.unde.re>2013-09-01 19:12:54 +0200
commitc95d4cafa90ab1775cae1fd5d70f098005f8b134 (patch)
treecf9d3728298f01b1c9327981a638e9c3d2acb1b4
parent76b1b5b6a31f8241a369f45da4de99a6dd71e2eb (diff)
downloadnextcloud-server-c95d4cafa90ab1775cae1fd5d70f098005f8b134.tar.gz
nextcloud-server-c95d4cafa90ab1775cae1fd5d70f098005f8b134.zip
Fix @tanghus's complains in avatars and clean up cropper after closing with "x"
-rw-r--r--core/avatar/controller.php36
-rw-r--r--settings/js/personal.js8
2 files changed, 36 insertions, 8 deletions
diff --git a/core/avatar/controller.php b/core/avatar/controller.php
index 8f1d6a57069..249c4cb6e2b 100644
--- a/core/avatar/controller.php
+++ b/core/avatar/controller.php
@@ -46,7 +46,11 @@ class OC_Core_Avatar_Controller {
if (!empty($_FILES)) {
$files = $_FILES['files'];
- if ($files['error'][0] === 0) {
+ if (
+ $files['error'][0] === 0 &&
+ is_uploaded_file($files['tmp_name'][0]) &&
+ !\OC\Files\Filesystem::isFileBlacklisted($files['tmp_name'][0])
+ ) {
$newAvatar = file_get_contents($files['tmp_name'][0]);
unlink($files['tmp_name'][0]);
}
@@ -59,8 +63,21 @@ class OC_Core_Avatar_Controller {
} catch (\OC\NotSquareException $e) {
$image = new \OC_Image($newAvatar);
- \OC_Cache::set('tmpavatar', $image->data(), 7200);
- \OC_JSON::error(array("data" => array("message" => "notsquare") ));
+ if ($image->valid()) {
+ \OC_Cache::set('tmpavatar', $image->data(), 7200);
+ \OC_JSON::error(array("data" => array("message" => "notsquare") ));
+ } else {
+ $l = new \OC_L10n('core');
+ $type = substr($image->mimeType(), -3);
+ if ($type === 'peg') { $type = 'jpg'; }
+ if ($type !== 'jpg' && $type !== 'png') {
+ \OC_JSON::error(array("data" => array("message" => $l->t("Unknown filetype")) ));
+ }
+
+ if (!$img->valid()) {
+ \OC_JSON::error(array("data" => array("message" => $l->t("Invalid image")) ));
+ }
+ }
} catch (\Exception $e) {
\OC_JSON::error(array("data" => array("message" => $e->getMessage()) ));
}
@@ -74,7 +91,7 @@ class OC_Core_Avatar_Controller {
$avatar->remove($user);
\OC_JSON::success();
} catch (\Exception $e) {
- \OC_JSON::error(array("data" => array ("message" => $e->getMessage()) ));
+ \OC_JSON::error(array("data" => array("message" => $e->getMessage()) ));
}
}
@@ -93,11 +110,18 @@ class OC_Core_Avatar_Controller {
public static function postCroppedAvatar($args) {
$user = OC_User::getUser();
- $crop = $_POST['crop'];
+ if (isset($_POST['crop'])) {
+ $crop = $_POST['crop'];
+ } else {
+ $l = new \OC_L10n('core');
+ \OC_JSON::error(array("data" => array("message" => $l->t("No crop data provided")) ));
+ return;
+ }
$tmpavatar = \OC_Cache::get('tmpavatar');
if ($tmpavatar === false) {
- \OC_JSON::error();
+ $l = new \OC_L10n('core');
+ \OC_JSON::error(array("data" => array("message" => $l->t("No temporary avatar available, try again")) ));
return;
}
diff --git a/settings/js/personal.js b/settings/js/personal.js
index e2e9c69e430..9823b2804bf 100644
--- a/settings/js/personal.js
+++ b/settings/js/personal.js
@@ -69,7 +69,8 @@ function showAvatarCropper() {
onSelect: saveCoords,
aspectRatio: 1,
boxHeight: 500,
- boxWidth: 500
+ boxWidth: 500,
+ setSelect: [0, 0, 300, 300]
});
$cropperbox.ocdialog({
@@ -77,7 +78,10 @@ function showAvatarCropper() {
text: t('settings', 'Crop'),
click: sendCropData,
defaultButton: true
- }]
+ }],
+ close: function(){
+ $(this).remove();
+ }
});
});
}