diff options
author | Vincent Petry <pvince81@owncloud.com> | 2015-08-18 16:24:23 +0200 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2015-08-18 16:24:23 +0200 |
commit | 2411662095142ce93d99f04d71f25b870109db62 (patch) | |
tree | 7f0bd4f24549a5bbf2edb71cf41ac60dd1b96b5f /core | |
parent | 08aaa334ccfc0814e404a46b85b8d667ad836284 (diff) | |
parent | 65cf4028cc418eba6ddd2aee124de8626148cb57 (diff) | |
download | nextcloud-server-2411662095142ce93d99f04d71f25b870109db62.tar.gz nextcloud-server-2411662095142ce93d99f04d71f25b870109db62.zip |
Merge pull request #14825 from rullzer/avatarcontroller_node
AvatarController to all OCP functions/Node API
Diffstat (limited to 'core')
-rw-r--r-- | core/application.php | 7 | ||||
-rw-r--r-- | core/avatar/avatarcontroller.php | 20 |
2 files changed, 19 insertions, 8 deletions
diff --git a/core/application.php b/core/application.php index 0fbb8dacdb7..373965e7fd7 100644 --- a/core/application.php +++ b/core/application.php @@ -82,7 +82,8 @@ class Application extends App { $c->query('Cache'), $c->query('L10N'), $c->query('UserManager'), - $c->query('UserSession') + $c->query('UserSession'), + $c->query('UserFolder') ); }); @@ -116,6 +117,10 @@ class Application extends App { $container->registerService('Cache', function(SimpleContainer $c) { return $c->query('ServerContainer')->getCache(); }); + $container->registerService('UserFolder', function(SimpleContainer $c) { + return $c->query('ServerContainer')->getUserFolder(); + }); + $container->registerService('Defaults', function() { diff --git a/core/avatar/avatarcontroller.php b/core/avatar/avatarcontroller.php index 2c4be827738..a0c9ebbd785 100644 --- a/core/avatar/avatarcontroller.php +++ b/core/avatar/avatarcontroller.php @@ -34,6 +34,7 @@ use OCP\IL10N; use OCP\IRequest; use OCP\IUserManager; use OCP\IUserSession; +use OCP\Files\Folder; /** * Class AvatarController @@ -57,6 +58,9 @@ class AvatarController extends Controller { /** @var IUserSession */ protected $userSession; + /** @var Folder */ + protected $userFolder; + /** * @param string $appName * @param IRequest $request @@ -65,6 +69,7 @@ class AvatarController extends Controller { * @param IL10N $l10n * @param IUserManager $userManager * @param IUserSession $userSession + * @param Folder $userFolder */ public function __construct($appName, IRequest $request, @@ -72,7 +77,8 @@ class AvatarController extends Controller { \OC\Cache\File $cache, IL10N $l10n, IUserManager $userManager, - IUserSession $userSession) { + IUserSession $userSession, + Folder $userFolder) { parent::__construct($appName, $request); $this->avatarManager = $avatarManager; @@ -80,6 +86,7 @@ class AvatarController extends Controller { $this->l = $l10n; $this->userManager = $userManager; $this->userSession = $userSession; + $this->userFolder = $userFolder; } /** @@ -133,12 +140,12 @@ class AvatarController extends Controller { if (isset($path)) { $path = stripslashes($path); - $view = new \OC\Files\View('/'.$userId.'/files'); - if ($view->filesize($path) > 20*1024*1024) { + $node = $this->userFolder->get($path); + if ($node->getSize() > 20*1024*1024) { return new DataResponse(['data' => ['message' => $this->l->t('File is too big')]], Http::STATUS_BAD_REQUEST); } - $fileName = $view->getLocalFile($path); + $content = $node->getContent(); } elseif (!is_null($files)) { if ( $files['error'][0] === 0 && @@ -150,8 +157,7 @@ class AvatarController extends Controller { Http::STATUS_BAD_REQUEST); } $this->cache->set('avatar_upload', file_get_contents($files['tmp_name'][0]), 7200); - $view = new \OC\Files\View('/'.$userId.'/cache'); - $fileName = $view->getLocalFile('avatar_upload'); + $content = $this->cache->get('avatar_upload'); unlink($files['tmp_name'][0]); } else { return new DataResponse(['data' => ['message' => $this->l->t('Invalid file provided')]], @@ -165,7 +171,7 @@ class AvatarController extends Controller { try { $image = new \OC_Image(); - $image->loadFromFile($fileName); + $image->loadFromData($content); $image->fixOrientation(); if ($image->valid()) { |