introducing class OCA/files/lib/Helper with new function to build an array with storage stats
DRYing the code by using \OCA\files\lib\Helper::buildFileStorageStatistics() now returning used space percent on each ajax call
This commit is contained in:
parent
afb5de955e
commit
cdd07b3339
|
@ -14,27 +14,18 @@ $files = json_decode($files);
|
||||||
$filesWithError = '';
|
$filesWithError = '';
|
||||||
$success = true;
|
$success = true;
|
||||||
//Now delete
|
//Now delete
|
||||||
foreach($files as $file) {
|
foreach ($files as $file) {
|
||||||
if( !OC_Files::delete( $dir, $file )) {
|
if (!OC_Files::delete($dir, $file)) {
|
||||||
$filesWithError .= $file . "\n";
|
$filesWithError .= $file . "\n";
|
||||||
$success = false;
|
$success = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// updated max file size after upload
|
// get array with updated storage stats (e.g. max file size) after upload
|
||||||
$l=new OC_L10N('files');
|
$storageStats = \OCA\files\lib\Helper::buildFileStorageStatistics($dir);
|
||||||
$maxUploadFilesize=OCP\Util::maxUploadFilesize($dir);
|
|
||||||
$maxHumanFilesize=OCP\Util::humanFileSize($maxUploadFilesize);
|
|
||||||
$maxHumanFilesize=$l->t('Upload') . ' max. '.$maxHumanFilesize;
|
|
||||||
|
|
||||||
if($success) {
|
if ($success) {
|
||||||
OCP\JSON::success(array("data" => array( "dir" => $dir, "files" => $files,
|
OCP\JSON::success(array("data" => array_merge(array("dir" => $dir, "files" => $files), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
|
||||||
)));
|
|
||||||
} else {
|
} else {
|
||||||
OCP\JSON::error(array("data" => array( "message" => "Could not delete:\n" . $filesWithError,
|
OCP\JSON::error(array("data" => array_merge(array("message" => "Could not delete:\n" . $filesWithError), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
|
||||||
)));
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,12 +5,5 @@ $RUNTIME_APPTYPES = array('filesystem');
|
||||||
|
|
||||||
OCP\JSON::checkLoggedIn();
|
OCP\JSON::checkLoggedIn();
|
||||||
|
|
||||||
$l=new OC_L10N('files');
|
|
||||||
$maxUploadFilesize = OCP\Util::maxUploadFilesize($dir);
|
|
||||||
$maxHumanFilesize = OCP\Util::humanFileSize($maxUploadFilesize);
|
|
||||||
$maxHumanFilesize = $l->t('Upload') . ' max. ' . $maxHumanFilesize;
|
|
||||||
|
|
||||||
// send back json
|
// send back json
|
||||||
OCP\JSON::success(array('data' => array('uploadMaxFilesize' => $maxUploadFilesize,
|
OCP\JSON::success(array('data' => \OCA\files\lib\Helper::buildFileStorageStatistics('/')));
|
||||||
'maxHumanFilesize' => $maxHumanFilesize
|
|
||||||
)));
|
|
||||||
|
|
|
@ -8,90 +8,73 @@ OCP\JSON::setContentTypeHeader('text/plain');
|
||||||
|
|
||||||
OCP\JSON::checkLoggedIn();
|
OCP\JSON::checkLoggedIn();
|
||||||
OCP\JSON::callCheck();
|
OCP\JSON::callCheck();
|
||||||
$l=OC_L10N::get('files');
|
$l = OC_L10N::get('files');
|
||||||
|
|
||||||
// current max upload size
|
// get array with current storage stats (e.g. max file size)
|
||||||
$l=new OC_L10N('files');
|
$storageStats = \OCA\files\lib\Helper::buildFileStorageStatistics($dir);
|
||||||
$maxUploadFilesize=OCP\Util::maxUploadFilesize($dir);
|
|
||||||
$maxHumanFilesize=OCP\Util::humanFileSize($maxUploadFilesize);
|
|
||||||
$maxHumanFilesize=$l->t('Upload') . ' max. '.$maxHumanFilesize;
|
|
||||||
|
|
||||||
if (!isset($_FILES['files'])) {
|
if (!isset($_FILES['files'])) {
|
||||||
OCP\JSON::error(array('data' => array( 'message' => $l->t( 'No file was uploaded. Unknown error' ),
|
OCP\JSON::error(array('data' => array_merge(array('message' => $l->t('No file was uploaded. Unknown error')), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
|
||||||
)));
|
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($_FILES['files']['error'] as $error) {
|
foreach ($_FILES['files']['error'] as $error) {
|
||||||
if ($error != 0) {
|
if ($error != 0) {
|
||||||
$errors = array(
|
$errors = array(
|
||||||
UPLOAD_ERR_OK=>$l->t('There is no error, the file uploaded with success'),
|
UPLOAD_ERR_OK => $l->t('There is no error, the file uploaded with success'),
|
||||||
UPLOAD_ERR_INI_SIZE=>$l->t('The uploaded file exceeds the upload_max_filesize directive in php.ini: ')
|
UPLOAD_ERR_INI_SIZE => $l->t('The uploaded file exceeds the upload_max_filesize directive in php.ini: ')
|
||||||
.ini_get('upload_max_filesize'),
|
. ini_get('upload_max_filesize'),
|
||||||
UPLOAD_ERR_FORM_SIZE=>$l->t('The uploaded file exceeds the MAX_FILE_SIZE directive that was specified'
|
UPLOAD_ERR_FORM_SIZE => $l->t('The uploaded file exceeds the MAX_FILE_SIZE directive that was specified'
|
||||||
.' in the HTML form'),
|
. ' in the HTML form'),
|
||||||
UPLOAD_ERR_PARTIAL=>$l->t('The uploaded file was only partially uploaded'),
|
UPLOAD_ERR_PARTIAL => $l->t('The uploaded file was only partially uploaded'),
|
||||||
UPLOAD_ERR_NO_FILE=>$l->t('No file was uploaded'),
|
UPLOAD_ERR_NO_FILE => $l->t('No file was uploaded'),
|
||||||
UPLOAD_ERR_NO_TMP_DIR=>$l->t('Missing a temporary folder'),
|
UPLOAD_ERR_NO_TMP_DIR => $l->t('Missing a temporary folder'),
|
||||||
UPLOAD_ERR_CANT_WRITE=>$l->t('Failed to write to disk'),
|
UPLOAD_ERR_CANT_WRITE => $l->t('Failed to write to disk'),
|
||||||
);
|
);
|
||||||
OCP\JSON::error(array('data' => array( 'message' => $errors[$error],
|
OCP\JSON::error(array('data' => array_merge(array('message' => $errors[$error]), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
|
||||||
)));
|
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$files=$_FILES['files'];
|
$files = $_FILES['files'];
|
||||||
|
|
||||||
$dir = $_POST['dir'];
|
$dir = $_POST['dir'];
|
||||||
$error='';
|
$error = '';
|
||||||
|
|
||||||
$totalSize=0;
|
$totalSize = 0;
|
||||||
foreach($files['size'] as $size) {
|
foreach ($files['size'] as $size) {
|
||||||
$totalSize+=$size;
|
$totalSize += $size;
|
||||||
}
|
}
|
||||||
if($totalSize>OC_Filesystem::free_space($dir)) {
|
if ($totalSize > OC_Filesystem::free_space($dir)) {
|
||||||
OCP\JSON::error(array('data' => array( 'message' => $l->t( 'Not enough storage available' ),
|
OCP\JSON::error(array('data' => array_merge(array('message' => $l->t('Not enough storage available')), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize)));
|
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$result=array();
|
$result = array();
|
||||||
if(strpos($dir, '..') === false) {
|
if (strpos($dir, '..') === false) {
|
||||||
$fileCount=count($files['name']);
|
$fileCount = count($files['name']);
|
||||||
for($i=0;$i<$fileCount;$i++) {
|
for ($i = 0; $i < $fileCount; $i++) {
|
||||||
$target = OCP\Files::buildNotExistingFileName(stripslashes($dir), $files['name'][$i]);
|
$target = OCP\Files::buildNotExistingFileName(stripslashes($dir), $files['name'][$i]);
|
||||||
// $path needs to be normalized - this failed within drag'n'drop upload to a sub-folder
|
// $path needs to be normalized - this failed within drag'n'drop upload to a sub-folder
|
||||||
$target = OC_Filesystem::normalizePath($target);
|
$target = OC_Filesystem::normalizePath($target);
|
||||||
if(is_uploaded_file($files['tmp_name'][$i]) and OC_Filesystem::fromTmpFile($files['tmp_name'][$i], $target)) {
|
if (is_uploaded_file($files['tmp_name'][$i]) and OC_Filesystem::fromTmpFile($files['tmp_name'][$i], $target)) {
|
||||||
$meta = OC_FileCache::get($target);
|
$meta = OC_FileCache::get($target);
|
||||||
$id = OC_FileCache::getId($target);
|
$id = OC_FileCache::getId($target);
|
||||||
// updated max file size after upload
|
|
||||||
$maxUploadFilesize=OCP\Util::maxUploadFilesize($dir);
|
|
||||||
$maxHumanFilesize=OCP\Util::humanFileSize($maxUploadFilesize);
|
|
||||||
$maxHumanFilesize=$l->t('Upload') . ' max. '.$maxHumanFilesize;
|
|
||||||
|
|
||||||
$result[]=array( 'status' => 'success',
|
// updated max file size after upload
|
||||||
'mime'=>$meta['mimetype'],
|
$storageStats = \OCA\files\lib\Helper::buildFileStorageStatistics($dir);
|
||||||
'size'=>$meta['size'],
|
|
||||||
'id'=>$id,
|
$result[] = array_merge(array('status' => 'success',
|
||||||
'name'=>basename($target),
|
'mime' => $meta['mimetype'],
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
'size' => $meta['size'],
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
'id' => $id,
|
||||||
|
'name' => basename($target)), $storageStats
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
OCP\JSON::encodedPrint($result);
|
OCP\JSON::encodedPrint($result);
|
||||||
exit();
|
exit();
|
||||||
} else {
|
} else {
|
||||||
$error=$l->t( 'Invalid directory.' );
|
$error = $l->t('Invalid directory.');
|
||||||
}
|
}
|
||||||
|
|
||||||
OCP\JSON::error(array('data' => array('message' => $error,
|
OCP\JSON::error(array('data' => array_merge(array('message' => $error), $storageStats)));
|
||||||
'uploadMaxFilesize'=>$maxUploadFilesize,
|
|
||||||
'maxHumanFilesize'=>$maxHumanFilesize
|
|
||||||
)));
|
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace OCA\files\lib;
|
||||||
|
|
||||||
|
class Helper
|
||||||
|
{
|
||||||
|
public static function buildFileStorageStatistics($dir) {
|
||||||
|
$l = new \OC_L10N('files');
|
||||||
|
$maxUploadFilesize = \OCP\Util::maxUploadFilesize($dir);
|
||||||
|
$maxHumanFilesize = \OCP\Util::humanFileSize($maxUploadFilesize);
|
||||||
|
$maxHumanFilesize = $l->t('Upload') . ' max. ' . $maxHumanFilesize;
|
||||||
|
|
||||||
|
// information about storage capacities
|
||||||
|
$storageInfo = \OC_Helper::getStorageInfo();
|
||||||
|
|
||||||
|
return array('uploadMaxFilesize' => $maxUploadFilesize,
|
||||||
|
'maxHumanFilesize' => $maxHumanFilesize,
|
||||||
|
'usedSpacePercent' => (int)$storageInfo['relative']);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue