PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` * @author Lukas Reschke * @author Martin Mattel * @author Morris Jobke * @author Robin Appelman * @author Roeland Jago Douma * @author Thomas Müller * @author Vincent Petry * * @copyright Copyright (c) 2018, ownCloud GmbH * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License, version 3, * along with this program. If not, see * */ namespace OC\Core\Controller; use OC\AppFramework\Http\Request; use OC\Cache\File; use OC\Files\Filesystem; use OC\NotSquareException; use OCP\AppFramework\Controller; use OCP\AppFramework\Http; use OCP\AppFramework\Http\DataResponse; use OCP\AppFramework\Http\DataDisplayResponse; use OCP\Files\IRootFolder; use OCP\Files\NotFoundException; use OCP\IAvatarManager; use OCP\ILogger; use OCP\IL10N; use OCP\IRequest; use OCP\IUserManager; use OCP\IUserSession; /** * Class AvatarController * * @package OC\Core\Controller */ class AvatarController extends Controller { /** @var IAvatarManager */ protected $avatarManager; /** @var File */ protected $cache; /** @var IL10N */ protected $l; /** @var IUserManager */ protected $userManager; /** @var IUserSession */ protected $userSession; /** @var IRootFolder */ protected $rootFolder; /** @var ILogger */ protected $logger; /** * @param string $appName * @param IRequest $request * @param IAvatarManager $avatarManager * @param File $cache * @param IL10N $l10n * @param IUserManager $userManager * @param IUserSession $userSession * @param IRootFolder $rootFolder * @param ILogger $logger */ public function __construct( $appName, IRequest $request, IAvatarManager $avatarManager, File $cache, IL10N $l10n, IUserManager $userManager, IUserSession $userSession, IRootFolder $rootFolder, ILogger $logger ) { parent::__construct($appName, $request); $this->avatarManager = $avatarManager; $this->cache = $cache; $this->l = $l10n; $this->userManager = $userManager; $this->userSession = $userSession; $this->rootFolder = $rootFolder; $this->logger = $logger; } /** * @NoAdminRequired * @NoCSRFRequired * * @param string $userId * @param int $size * @return DataResponse|DataDisplayResponse */ public function getAvatar($userId, $size) { if ($size > 2048) { $size = 2048; } elseif ($size <= 0) { $size = 64; } try { $avatar = $this->avatarManager->getAvatar($userId)->getFile($size); $resp = new DataDisplayResponse( $avatar->getContent(), Http::STATUS_OK, ['Content-Type' => $avatar->getMimeType()] ); $resp->setETag($avatar->getEtag()); } catch (NotFoundException $e) { $user = $this->userManager->get($userId); $resp = new DataResponse([ 'data' => [ 'displayname' => $user->getDisplayName(), ], ]); } catch (\Exception $e) { $resp = new DataResponse([ 'data' => [ 'displayname' => '', ], ]); } $resp->addHeader('Pragma', 'public'); $resp->cacheFor(0); $resp->setLastModified(new \DateTime('now', new \DateTimeZone('GMT'))); return $resp; } /** * @NoAdminRequired * * @param string $path * @return DataResponse */ public function postAvatar($path) { $userId = $this->userSession->getUser()->getUID(); $files = $this->request->getUploadedFile('files'); $tmpImage = null; $headers = []; if ($this->request->isUserAgent([Request::USER_AGENT_IE_8])) { // due to upload iframe workaround, need to set content-type to text/plain $headers['Content-Type'] = 'text/plain'; } if (isset($path)) { $path = \stripslashes($path); $node = $this->rootFolder->getUserFolder($userId)->get($path); if (!($node instanceof \OCP\Files\File)) { return new DataResponse(['data' => ['message' => $this->l->t('Please select a file.')]], Http::STATUS_OK, $headers); } if ($node->getSize() > 20*1024*1024) { return new DataResponse( ['data' => ['message' => $this->l->t('File is too big')]], Http::STATUS_BAD_REQUEST, $headers ); } $handle = $node->fopen('r'); } elseif ($files !== null) { if ( $files['error'][0] === 0 && $this->isUploadFile($files['tmp_name'][0]) && !Filesystem::isForbiddenFileOrDir($files['tmp_name'][0]) ) { if ($files['size'][0] > 20*1024*1024) { return new DataResponse( ['data' => ['message' => $this->l->t('File is too big')]], Http::STATUS_BAD_REQUEST, $headers ); } $tmpImage = $files['tmp_name'][0]; $handle = \fopen($tmpImage, 'r'); } else { return new DataResponse( ['data' => ['message' => $this->l->t('Invalid file provided')]], Http::STATUS_BAD_REQUEST, $headers ); } } else { //Add imgfile return new DataResponse( ['data' => ['message' => $this->l->t('No image or file provided')]], Http::STATUS_BAD_REQUEST, $headers ); } try { $image = new \OC_Image(); $image->load($handle); $image->fixOrientation(); if ($image->valid()) { $mimeType = $image->mimeType(); if ($mimeType !== 'image/jpeg' && $mimeType !== 'image/png') { return new DataResponse( ['data' => ['message' => $this->l->t('Unknown filetype')]], Http::STATUS_OK, $headers ); } $this->cache->set('tmpAvatar', $image->data(), 7200); return new DataResponse( ['data' => 'notsquare'], Http::STATUS_OK, $headers ); } else { return new DataResponse( ['data' => ['message' => $this->l->t('Invalid image')]], Http::STATUS_OK, $headers ); } } catch (\Exception $e) { $this->logger->logException($e, ['app' => 'core']); return new DataResponse(['data' => ['message' => $this->l->t('An error occurred. Please contact your admin.')]], Http::STATUS_OK, $headers); } finally { if (\is_resource($handle)) { \fclose($handle); } if ($tmpImage) { \unlink($tmpImage); } } } /** * @NoAdminRequired * * @return DataResponse */ public function deleteAvatar() { $userId = $this->userSession->getUser()->getUID(); try { $avatar = $this->avatarManager->getAvatar($userId); $avatar->remove(); return new DataResponse(); } catch (\Exception $e) { $this->logger->logException($e, ['app' => 'core']); return new DataResponse(['data' => ['message' => $this->l->t('An error occurred. Please contact your admin.')]], Http::STATUS_BAD_REQUEST); } } /** * @NoAdminRequired * * @return DataResponse|DataDisplayResponse */ public function getTmpAvatar() { $tmpAvatar = $this->cache->get('tmpAvatar'); if ($tmpAvatar === null) { return new DataResponse( ['data' => [ 'message' => $this->l->t("No temporary profile picture available, try again") ]], Http::STATUS_NOT_FOUND ); } $image = new \OC_Image($tmpAvatar); $resp = new DataDisplayResponse( $image->data(), Http::STATUS_OK, ['Content-Type' => $image->mimeType()] ); $resp->setETag(\crc32($image->data())); $resp->cacheFor(0); $resp->setLastModified(new \DateTime('now', new \DateTimeZone('GMT'))); return $resp; } /** * @NoAdminRequired * * @param array $crop * @return DataResponse */ public function postCroppedAvatar($crop) { $userId = $this->userSession->getUser()->getUID(); if ($crop === null) { return new DataResponse( ['data' => ['message' => $this->l->t("No crop data provided")]], Http::STATUS_BAD_REQUEST ); } if (!isset($crop['x'], $crop['y'], $crop['w'], $crop['h'])) { return new DataResponse( ['data' => ['message' => $this->l->t("No valid crop data provided")]], Http::STATUS_BAD_REQUEST ); } $tmpAvatar = $this->cache->get('tmpAvatar'); if ($tmpAvatar === null) { return new DataResponse( ['data' => [ 'message' => $this->l->t("No temporary profile picture available, try again") ]], Http::STATUS_BAD_REQUEST ); } $image = new \OC_Image($tmpAvatar); $image->crop($crop['x'], $crop['y'], \round($crop['w']), \round($crop['h'])); try { $avatar = $this->avatarManager->getAvatar($userId); $avatar->set($image); // Clean up $this->cache->remove('tmpAvatar'); return new DataResponse(['status' => 'success']); } catch (NotSquareException $e) { return new DataResponse( ['data' => ['message' => $this->l->t('Crop is not square')]], Http::STATUS_BAD_REQUEST ); } catch (\Exception $e) { $this->logger->logException($e, ['app' => 'core']); return new DataResponse(['data' => ['message' => $this->l->t('An error occurred. Please contact your admin.')]], Http::STATUS_BAD_REQUEST); } } /** * @param string $file * @return bool */ protected function isUploadFile($file) { return \is_uploaded_file($file); } }