aboutsummaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2015-08-18 16:24:23 +0200
committerVincent Petry <pvince81@owncloud.com>2015-08-18 16:24:23 +0200
commit2411662095142ce93d99f04d71f25b870109db62 (patch)
tree7f0bd4f24549a5bbf2edb71cf41ac60dd1b96b5f /core
parent08aaa334ccfc0814e404a46b85b8d667ad836284 (diff)
parent65cf4028cc418eba6ddd2aee124de8626148cb57 (diff)
downloadnextcloud-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.php7
-rw-r--r--core/avatar/avatarcontroller.php20
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()) {