2011-03-03 00:18:22 +03:00
< ? php
/**
2015-03-26 13:44:34 +03:00
* @ author Arthur Schiwon < blizzz @ owncloud . com >
* @ author Bart Visscher < bartv @ thisnet . nl >
* @ author Björn Schießle < schiessle @ owncloud . com >
* @ author Christopher Schäpers < kondou @ ts . unde . re >
* @ author Fabian Henze < flyser42 @ gmx . de >
* @ author Felix Moeller < mail @ felixmoeller . de >
* @ author François Kubler < francois @ kubler . org >
* @ author Frank Karlitschek < frank @ owncloud . org >
* @ author Georg Ehrke < georg @ owncloud . com >
* @ author Georg Ehrke < georg @ ownCloud . com >
* @ author Jakob Sack < mail @ jakobsack . de >
* @ author Jan - Christoph Borchardt < hey @ jancborchardt . net >
* @ author Joas Schilling < nickvergessen @ owncloud . com >
* @ author Jörn Friedrich Dreyer < jfd @ butonic . de >
* @ author Lukas Reschke < lukas @ owncloud . com >
* @ author Michael Gapczynski < GapczynskiM @ gmail . com >
* @ author Morris Jobke < hey @ morrisjobke . de >
* @ author Olivier Paroz < github @ oparoz . com >
* @ author Owen Winkler < a_github @ midnightcircus . com >
* @ author Pellaeon Lin < nfsmwlin @ gmail . com >
* @ author Robin Appelman < icewind @ owncloud . com >
* @ author Robin McCorkell < rmccorkell @ karoshi . org . uk >
* @ author Roeland Jago Douma < roeland @ famdouma . nl >
* @ author Simon Könnecke < simonkoennecke @ gmail . com >
* @ author Thomas Müller < thomas . mueller @ tmit . eu >
* @ author Thomas Tanghus < thomas @ tanghus . net >
* @ author Valerio Ponte < valerio . ponte @ gmail . com >
* @ author Vincent Petry < pvince81 @ owncloud . com >
2011-03-13 19:25:34 +03:00
*
2015-03-26 13:44:34 +03:00
* @ copyright Copyright ( c ) 2015 , ownCloud , Inc .
* @ license AGPL - 3.0
2011-03-13 19:25:34 +03:00
*
2015-03-26 13:44:34 +03:00
* 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 .
2011-03-13 19:25:34 +03:00
*
2015-03-26 13:44:34 +03:00
* This program is distributed in the hope that it will be useful ,
2011-03-13 19:25:34 +03:00
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
2015-03-26 13:44:34 +03:00
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Affero General Public License for more details .
2011-03-13 19:25:34 +03:00
*
2015-03-26 13:44:34 +03:00
* You should have received a copy of the GNU Affero General Public License , version 3 ,
* along with this program . If not , see < http :// www . gnu . org / licenses />
2011-03-13 19:25:34 +03:00
*
*/
2015-02-26 13:37:37 +03:00
/**
* Collection of useful functions
*/
2011-07-29 23:36:03 +04:00
class OC_Helper {
2013-05-29 17:43:41 +04:00
private static $mimetypeIcons = array ();
2013-08-07 18:38:57 +04:00
private static $mimetypeDetector ;
2013-08-07 18:53:09 +04:00
private static $templateManager ;
2015-01-18 16:48:24 +03:00
/** @var string[] */
private static $mimeTypeAlias = array (
'application/octet-stream' => 'file' , // use file icon as fallback
'application/illustrator' => 'image/vector' ,
'application/postscript' => 'image/vector' ,
'image/svg+xml' => 'image/vector' ,
'application/coreldraw' => 'image' ,
'application/x-gimp' => 'image' ,
'application/x-photoshop' => 'image' ,
2015-03-16 18:25:04 +03:00
'application/x-dcraw' => 'image' ,
2015-01-18 16:48:24 +03:00
2014-11-26 21:58:59 +03:00
'application/font-sfnt' => 'font' ,
'application/x-font' => 'font' ,
2015-01-18 16:48:24 +03:00
'application/font-woff' => 'font' ,
'application/vnd.ms-fontobject' => 'font' ,
'application/json' => 'text/code' ,
'application/x-perl' => 'text/code' ,
'application/x-php' => 'text/code' ,
'text/x-shellscript' => 'text/code' ,
'application/xml' => 'text/html' ,
'text/css' => 'text/code' ,
'application/x-tex' => 'text' ,
'application/x-compressed' => 'package/x-generic' ,
'application/x-7z-compressed' => 'package/x-generic' ,
'application/x-deb' => 'package/x-generic' ,
'application/x-gzip' => 'package/x-generic' ,
'application/x-rar-compressed' => 'package/x-generic' ,
'application/x-tar' => 'package/x-generic' ,
'application/vnd.android.package-archive' => 'package/x-generic' ,
'application/zip' => 'package/x-generic' ,
'application/msword' => 'x-office/document' ,
'application/vnd.openxmlformats-officedocument.wordprocessingml.document' => 'x-office/document' ,
'application/vnd.openxmlformats-officedocument.wordprocessingml.template' => 'x-office/document' ,
'application/vnd.ms-word.document.macroEnabled.12' => 'x-office/document' ,
'application/vnd.ms-word.template.macroEnabled.12' => 'x-office/document' ,
'application/vnd.oasis.opendocument.text' => 'x-office/document' ,
'application/vnd.oasis.opendocument.text-template' => 'x-office/document' ,
'application/vnd.oasis.opendocument.text-web' => 'x-office/document' ,
'application/vnd.oasis.opendocument.text-master' => 'x-office/document' ,
'application/mspowerpoint' => 'x-office/presentation' ,
'application/vnd.ms-powerpoint' => 'x-office/presentation' ,
'application/vnd.openxmlformats-officedocument.presentationml.presentation' => 'x-office/presentation' ,
'application/vnd.openxmlformats-officedocument.presentationml.template' => 'x-office/presentation' ,
'application/vnd.openxmlformats-officedocument.presentationml.slideshow' => 'x-office/presentation' ,
'application/vnd.ms-powerpoint.addin.macroEnabled.12' => 'x-office/presentation' ,
'application/vnd.ms-powerpoint.presentation.macroEnabled.12' => 'x-office/presentation' ,
'application/vnd.ms-powerpoint.template.macroEnabled.12' => 'x-office/presentation' ,
'application/vnd.ms-powerpoint.slideshow.macroEnabled.12' => 'x-office/presentation' ,
'application/vnd.oasis.opendocument.presentation' => 'x-office/presentation' ,
'application/vnd.oasis.opendocument.presentation-template' => 'x-office/presentation' ,
'application/msexcel' => 'x-office/spreadsheet' ,
'application/vnd.ms-excel' => 'x-office/spreadsheet' ,
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' => 'x-office/spreadsheet' ,
'application/vnd.openxmlformats-officedocument.spreadsheetml.template' => 'x-office/spreadsheet' ,
'application/vnd.ms-excel.sheet.macroEnabled.12' => 'x-office/spreadsheet' ,
'application/vnd.ms-excel.template.macroEnabled.12' => 'x-office/spreadsheet' ,
'application/vnd.ms-excel.addin.macroEnabled.12' => 'x-office/spreadsheet' ,
'application/vnd.ms-excel.sheet.binary.macroEnabled.12' => 'x-office/spreadsheet' ,
'application/vnd.oasis.opendocument.spreadsheet' => 'x-office/spreadsheet' ,
'application/vnd.oasis.opendocument.spreadsheet-template' => 'x-office/spreadsheet' ,
'text/csv' => 'x-office/spreadsheet' ,
'application/msaccess' => 'database' ,
);
2012-04-14 00:59:47 +04:00
2012-09-12 20:00:33 +04:00
/**
2014-05-19 19:50:53 +04:00
* Creates an url using a defined route
2014-05-12 00:51:30 +04:00
* @ param string $route
2013-01-05 02:00:51 +04:00
* @ param array $parameters
* @ return
* @ internal param array $args with param => value , will be appended to the returned url
2014-05-11 21:05:28 +04:00
* @ return string the url
2012-09-12 20:00:33 +04:00
*
* Returns a url to the given app and file .
*/
2013-08-07 18:38:57 +04:00
public static function linkToRoute ( $route , $parameters = array ()) {
2013-09-26 20:41:19 +04:00
return OC :: $server -> getURLGenerator () -> linkToRoute ( $route , $parameters );
2012-09-12 20:00:33 +04:00
}
2011-03-03 00:18:22 +03:00
/**
2014-05-19 19:50:53 +04:00
* Creates an url
2012-09-23 04:39:11 +04:00
* @ param string $app app
* @ param string $file file
* @ param array $args array with param => value , will be appended to the returned url
2013-08-07 18:38:57 +04:00
* The value of $args will be urlencoded
2012-09-23 04:39:11 +04:00
* @ return string the url
2011-03-03 00:18:22 +03:00
*
2011-03-13 19:25:34 +03:00
* Returns a url to the given app and file .
2011-03-03 00:18:22 +03:00
*/
2012-09-07 17:22:01 +04:00
public static function linkTo ( $app , $file , $args = array () ) {
2013-09-26 20:41:19 +04:00
return OC :: $server -> getURLGenerator () -> linkTo ( $app , $file , $args );
2011-03-03 00:18:22 +03:00
}
2013-10-22 00:01:27 +04:00
/**
2014-11-24 18:24:26 +03:00
* @ param string $key
2013-10-22 00:01:27 +04:00
* @ return string url to the online documentation
*/
public static function linkToDocs ( $key ) {
2014-11-24 18:24:26 +03:00
return OC :: $server -> getURLGenerator () -> linkToDocs ( $key );
2013-10-22 00:01:27 +04:00
}
2012-02-16 22:45:00 +04:00
/**
2014-05-19 19:50:53 +04:00
* Creates an absolute url
2012-09-23 04:39:11 +04:00
* @ param string $app app
* @ param string $file file
* @ param array $args array with param => value , will be appended to the returned url
2013-08-07 18:38:57 +04:00
* The value of $args will be urlencoded
2012-09-23 04:39:11 +04:00
* @ return string the url
2012-02-16 22:45:00 +04:00
*
* Returns a absolute url to the given app and file .
*/
2013-08-07 18:38:57 +04:00
public static function linkToAbsolute ( $app , $file , $args = array ()) {
2014-04-16 16:30:24 +04:00
return OC :: $server -> getURLGenerator () -> getAbsoluteURL (
self :: linkTo ( $app , $file , $args )
);
2012-08-07 00:15:55 +04:00
}
/**
2014-05-19 19:50:53 +04:00
* Makes an $url absolute
2012-09-23 04:39:11 +04:00
* @ param string $url the url
* @ return string the absolute url
2012-08-07 00:15:55 +04:00
*
* Returns a absolute url to the given app and file .
*/
2013-08-07 18:38:57 +04:00
public static function makeURLAbsolute ( $url ) {
2013-10-07 02:35:05 +04:00
return OC :: $server -> getURLGenerator () -> getAbsoluteURL ( $url );
2012-02-16 22:45:00 +04:00
}
2012-10-17 12:52:16 +04:00
/**
2014-05-19 19:50:53 +04:00
* Creates an url for remote use
2012-10-17 12:52:16 +04:00
* @ param string $service id
* @ return string the url
*
* Returns a url to the given service .
*/
2013-08-07 18:38:57 +04:00
public static function linkToRemoteBase ( $service ) {
return self :: linkTo ( '' , 'remote.php' ) . '/' . $service ;
2012-10-17 12:52:16 +04:00
}
2012-05-07 22:22:55 +04:00
/**
2014-05-19 19:50:53 +04:00
* Creates an absolute url for remote use
2012-09-23 04:39:11 +04:00
* @ param string $service id
2013-01-05 02:00:51 +04:00
* @ param bool $add_slash
2012-09-23 04:39:11 +04:00
* @ return string the url
2012-05-07 22:22:55 +04:00
*
* Returns a absolute url to the given service .
*/
2013-08-07 18:38:57 +04:00
public static function linkToRemote ( $service , $add_slash = true ) {
2014-04-16 16:30:24 +04:00
return OC :: $server -> getURLGenerator () -> getAbsoluteURL (
self :: linkToRemoteBase ( $service )
. (( $add_slash && $service [ strlen ( $service ) - 1 ] != '/' ) ? '/' : '' )
);
2012-05-07 22:22:55 +04:00
}
2012-08-27 23:46:05 +04:00
/**
2014-05-19 19:50:53 +04:00
* Creates an absolute url for public use
2012-09-23 04:39:11 +04:00
* @ param string $service id
2013-01-05 02:00:51 +04:00
* @ param bool $add_slash
2012-09-23 04:39:11 +04:00
* @ return string the url
2012-08-27 23:46:05 +04:00
*
* Returns a absolute url to the given service .
*/
public static function linkToPublic ( $service , $add_slash = false ) {
2014-09-04 21:51:38 +04:00
if ( $service === 'files' ) {
$url = OC :: $server -> getURLGenerator () -> getAbsoluteURL ( '/s' );
} else {
$url = OC :: $server -> getURLGenerator () -> getAbsoluteURL ( self :: linkTo ( '' , 'public.php' ) . '?service=' . $service );
}
return $url . (( $add_slash && $service [ strlen ( $service ) - 1 ] != '/' ) ? '/' : '' );
2012-08-27 23:46:05 +04:00
}
2011-03-03 00:18:22 +03:00
/**
2014-05-19 19:50:53 +04:00
* Creates path to an image
2012-09-23 04:39:11 +04:00
* @ param string $app app
* @ param string $image image name
* @ return string the url
2011-03-03 00:18:22 +03:00
*
2011-03-13 19:25:34 +03:00
* Returns the path to the image .
2011-03-03 00:18:22 +03:00
*/
2013-08-07 18:38:57 +04:00
public static function imagePath ( $app , $image ) {
2013-09-26 20:41:19 +04:00
return OC :: $server -> getURLGenerator () -> imagePath ( $app , $image );
2012-02-27 21:01:43 +04:00
}
2011-03-03 00:18:22 +03:00
/**
2014-05-19 19:50:53 +04:00
* get path to icon of file type
2012-09-23 04:39:11 +04:00
* @ param string $mimetype mimetype
* @ return string the url
2011-03-03 00:18:22 +03:00
*
2011-08-11 20:59:01 +04:00
* Returns the path to the image of this file type .
2011-03-03 00:18:22 +03:00
*/
2013-05-29 18:56:28 +04:00
public static function mimetypeIcon ( $mimetype ) {
2013-08-15 15:20:31 +04:00
2015-01-18 16:48:24 +03:00
if ( isset ( self :: $mimeTypeAlias [ $mimetype ])) {
$mimetype = self :: $mimeTypeAlias [ $mimetype ];
2011-10-08 23:18:47 +04:00
}
2013-05-29 17:43:41 +04:00
if ( isset ( self :: $mimetypeIcons [ $mimetype ])) {
return self :: $mimetypeIcons [ $mimetype ];
}
2013-01-19 22:45:28 +04:00
// Replace slash and backslash with a minus
2013-05-29 18:56:28 +04:00
$icon = str_replace ( '/' , '-' , $mimetype );
2013-08-07 18:38:57 +04:00
$icon = str_replace ( '\\' , '-' , $icon );
2011-03-03 00:18:22 +03:00
// Is it a dir?
2013-05-29 18:56:28 +04:00
if ( $mimetype === 'dir' ) {
2013-08-07 18:38:57 +04:00
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/folder.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/folder.png' ;
2011-03-03 00:18:22 +03:00
}
2013-09-12 02:12:20 +04:00
if ( $mimetype === 'dir-shared' ) {
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/folder-shared.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/folder-shared.png' ;
}
if ( $mimetype === 'dir-external' ) {
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/folder-external.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/folder-external.png' ;
}
2011-03-03 00:18:22 +03:00
// Icon exists?
2013-08-07 18:38:57 +04:00
if ( file_exists ( OC :: $SERVERROOT . '/core/img/filetypes/' . $icon . '.png' )) {
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/' . $icon . '.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/' . $icon . '.png' ;
2011-07-29 03:36:31 +04:00
}
2013-05-29 18:56:28 +04:00
// Try only the first part of the filetype
$mimePart = substr ( $icon , 0 , strpos ( $icon , '-' ));
2013-08-07 18:38:57 +04:00
if ( file_exists ( OC :: $SERVERROOT . '/core/img/filetypes/' . $mimePart . '.png' )) {
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/' . $mimePart . '.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/' . $mimePart . '.png' ;
2013-05-29 18:56:28 +04:00
} else {
2013-08-07 18:38:57 +04:00
self :: $mimetypeIcons [ $mimetype ] = OC :: $WEBROOT . '/core/img/filetypes/file.png' ;
return OC :: $WEBROOT . '/core/img/filetypes/file.png' ;
2011-03-03 00:18:22 +03:00
}
}
2011-03-03 00:28:32 +03:00
2013-06-26 20:04:18 +04:00
/**
2014-05-19 19:50:53 +04:00
* get path to preview of file
2013-06-26 20:04:18 +04:00
* @ param string $path path
* @ return string the url
*
* Returns the path to the preview of the file .
*/
public static function previewIcon ( $path ) {
2013-10-28 14:22:34 +04:00
return self :: linkToRoute ( 'core_ajax_preview' , array ( 'x' => 36 , 'y' => 36 , 'file' => $path ));
2013-06-26 20:04:18 +04:00
}
2013-07-30 14:29:12 +04:00
public static function publicPreviewIcon ( $path , $token ) {
2013-10-28 14:22:34 +04:00
return self :: linkToRoute ( 'core_ajax_public_preview' , array ( 'x' => 36 , 'y' => 36 , 'file' => $path , 't' => $token ));
2013-07-11 13:58:52 +04:00
}
2014-03-15 18:27:48 +04:00
/**
* shows whether the user has an avatar
* @ param string $user username
* @ return bool avatar set or not
**/
public static function userAvatarSet ( $user ) {
2015-03-03 14:52:27 +03:00
$avatar = new \OC\Avatar ( $user );
2015-02-03 16:54:06 +03:00
return $avatar -> exists ();
2014-03-15 18:27:48 +04:00
}
2011-03-03 00:28:32 +03:00
/**
2014-05-19 19:50:53 +04:00
* Make a human file size
2012-09-23 04:39:11 +04:00
* @ param int $bytes file size in bytes
* @ return string a human readable file size
2011-03-03 00:28:32 +03:00
*
2011-03-13 19:25:34 +03:00
* Makes 2048 to 2 kB .
2011-03-03 00:28:32 +03:00
*/
2013-08-07 18:38:57 +04:00
public static function humanFileSize ( $bytes ) {
if ( $bytes < 0 ) {
2013-08-04 18:27:17 +04:00
return " ? " ;
2013-01-15 02:39:31 +04:00
}
2013-08-07 18:38:57 +04:00
if ( $bytes < 1024 ) {
2011-03-03 00:28:32 +03:00
return " $bytes B " ;
}
2013-11-25 15:26:03 +04:00
$bytes = round ( $bytes / 1024 , 0 );
2013-08-07 18:38:57 +04:00
if ( $bytes < 1024 ) {
2011-03-03 00:28:32 +03:00
return " $bytes kB " ;
}
2013-08-07 18:38:57 +04:00
$bytes = round ( $bytes / 1024 , 1 );
if ( $bytes < 1024 ) {
2011-03-03 00:28:32 +03:00
return " $bytes MB " ;
}
2013-09-13 19:22:45 +04:00
$bytes = round ( $bytes / 1024 , 1 );
if ( $bytes < 1024 ) {
return " $bytes GB " ;
}
$bytes = round ( $bytes / 1024 , 1 );
if ( $bytes < 1024 ) {
return " $bytes TB " ;
}
2011-03-03 00:28:32 +03:00
2013-08-07 18:38:57 +04:00
$bytes = round ( $bytes / 1024 , 1 );
2013-09-13 19:22:45 +04:00
return " $bytes PB " ;
2011-03-03 00:28:32 +03:00
}
2012-04-14 00:59:47 +04:00
2014-04-03 03:17:28 +04:00
/**
2014-05-19 19:50:53 +04:00
* Make a php file size
2014-04-03 03:17:28 +04:00
* @ param int $bytes file size in bytes
* @ return string a php parseable file size
*
* Makes 2048 to 2 k and 2 ^ 41 to 2048 G
*/
public static function phpFileSize ( $bytes ) {
if ( $bytes < 0 ) {
return " ? " ;
}
if ( $bytes < 1024 ) {
return $bytes . " B " ;
}
$bytes = round ( $bytes / 1024 , 1 );
if ( $bytes < 1024 ) {
return $bytes . " K " ;
}
$bytes = round ( $bytes / 1024 , 1 );
if ( $bytes < 1024 ) {
return $bytes . " M " ;
}
$bytes = round ( $bytes / 1024 , 1 );
return $bytes . " G " ;
}
2011-04-17 14:03:23 +04:00
/**
2014-05-19 19:50:53 +04:00
* Make a computer file size
2014-03-17 15:15:12 +04:00
* @ param string $str file size in human readable format
2012-09-23 04:39:11 +04:00
* @ return int a file size in bytes
2011-04-17 14:03:23 +04:00
*
* Makes 2 kB to 2048.
*
* Inspired by : http :// www . php . net / manual / en / function . filesize . php #92418
*/
2013-08-07 18:38:57 +04:00
public static function computerFileSize ( $str ) {
$str = strtolower ( $str );
2011-04-17 14:03:23 +04:00
$bytes_array = array (
2011-12-12 02:33:24 +04:00
'b' => 1 ,
'k' => 1024 ,
'kb' => 1024 ,
'mb' => 1024 * 1024 ,
2013-08-07 18:38:57 +04:00
'm' => 1024 * 1024 ,
2011-12-12 02:33:24 +04:00
'gb' => 1024 * 1024 * 1024 ,
2013-08-07 18:38:57 +04:00
'g' => 1024 * 1024 * 1024 ,
2011-12-12 02:33:24 +04:00
'tb' => 1024 * 1024 * 1024 * 1024 ,
2013-08-07 18:38:57 +04:00
't' => 1024 * 1024 * 1024 * 1024 ,
2011-12-12 02:33:24 +04:00
'pb' => 1024 * 1024 * 1024 * 1024 * 1024 ,
2013-08-07 18:38:57 +04:00
'p' => 1024 * 1024 * 1024 * 1024 * 1024 ,
2011-04-17 14:03:23 +04:00
);
$bytes = floatval ( $str );
2011-12-12 02:33:24 +04:00
if ( preg_match ( '#([kmgtp]?b?)$#si' , $str , $matches ) && ! empty ( $bytes_array [ $matches [ 1 ]])) {
2011-04-17 14:03:23 +04:00
$bytes *= $bytes_array [ $matches [ 1 ]];
}
2014-03-17 15:15:12 +04:00
$bytes = round ( $bytes );
2011-04-17 14:03:23 +04:00
2012-04-14 00:59:47 +04:00
return $bytes ;
2011-04-17 14:03:23 +04:00
}
2012-04-14 00:59:47 +04:00
2011-05-28 19:33:25 +04:00
/**
2014-05-19 19:50:53 +04:00
* Recursive copying of folders
2011-05-28 19:33:25 +04:00
* @ param string $src source folder
* @ param string $dest target folder
*
*/
static function copyr ( $src , $dest ) {
2013-08-07 18:38:57 +04:00
if ( is_dir ( $src )) {
if ( ! is_dir ( $dest )) {
2011-05-28 19:33:25 +04:00
mkdir ( $dest );
}
$files = scandir ( $src );
2012-09-07 17:22:01 +04:00
foreach ( $files as $file ) {
if ( $file != " . " && $file != " .. " ) {
2011-05-28 19:33:25 +04:00
self :: copyr ( " $src / $file " , " $dest / $file " );
}
}
2013-08-07 18:38:57 +04:00
} elseif ( file_exists ( $src ) && ! \OC\Files\Filesystem :: isFileBlacklisted ( $src )) {
2011-05-28 19:33:25 +04:00
copy ( $src , $dest );
}
}
2012-04-14 00:59:47 +04:00
2011-05-28 19:33:25 +04:00
/**
2014-05-19 19:50:53 +04:00
* Recursive deletion of folders
2011-05-28 19:33:25 +04:00
* @ param string $dir path to the folder
2014-10-06 14:38:59 +04:00
* @ param bool $deleteSelf if set to false only the content of the folder will be deleted
2012-09-23 04:39:11 +04:00
* @ return bool
2011-05-28 19:33:25 +04:00
*/
2014-10-06 14:38:59 +04:00
static function rmdirr ( $dir , $deleteSelf = true ) {
2013-08-07 18:38:57 +04:00
if ( is_dir ( $dir )) {
2014-06-23 15:33:55 +04:00
$files = new RecursiveIteratorIterator (
new RecursiveDirectoryIterator ( $dir , RecursiveDirectoryIterator :: SKIP_DOTS ),
RecursiveIteratorIterator :: CHILD_FIRST
);
foreach ( $files as $fileInfo ) {
2014-06-24 01:15:30 +04:00
/** @var SplFileInfo $fileInfo */
2014-06-23 15:33:55 +04:00
if ( $fileInfo -> isDir ()) {
rmdir ( $fileInfo -> getRealPath ());
} else {
unlink ( $fileInfo -> getRealPath ());
2011-05-28 19:33:25 +04:00
}
}
2014-10-06 14:38:59 +04:00
if ( $deleteSelf ) {
rmdir ( $dir );
}
2013-08-07 18:38:57 +04:00
} elseif ( file_exists ( $dir )) {
2014-10-06 14:38:59 +04:00
if ( $deleteSelf ) {
unlink ( $dir );
}
2011-05-28 19:33:25 +04:00
}
2014-10-06 14:38:59 +04:00
if ( ! $deleteSelf ) {
2012-09-23 04:39:11 +04:00
return true ;
2012-04-14 00:59:47 +04:00
}
2014-10-06 14:38:59 +04:00
return ! file_exists ( $dir );
2011-05-28 19:33:25 +04:00
}
2012-02-16 00:44:58 +04:00
2013-08-07 18:53:09 +04:00
/**
* @ return \OC\Files\Type\Detection
*/
2013-08-07 18:38:57 +04:00
static public function getMimetypeDetector () {
if ( ! self :: $mimetypeDetector ) {
self :: $mimetypeDetector = new \OC\Files\Type\Detection ();
self :: $mimetypeDetector -> registerTypeArray ( include 'mimetypes.list.php' );
}
return self :: $mimetypeDetector ;
}
2013-08-07 18:53:09 +04:00
/**
* @ return \OC\Files\Type\TemplateManager
*/
static public function getFileTemplateManager () {
if ( ! self :: $templateManager ) {
self :: $templateManager = new \OC\Files\Type\TemplateManager ();
}
return self :: $templateManager ;
}
2012-02-16 00:44:58 +04:00
/**
2013-06-07 01:51:44 +04:00
* Try to guess the mimetype based on filename
*
2013-06-07 02:17:51 +04:00
* @ param string $path
2012-02-16 00:44:58 +04:00
* @ return string
*/
2013-08-07 18:38:57 +04:00
static public function getFileNameMimeType ( $path ) {
return self :: getMimetypeDetector () -> detectPath ( $path );
2013-06-07 01:51:44 +04:00
}
/**
* get the mimetype form a local file
2013-08-07 18:38:57 +04:00
*
2013-06-07 01:51:44 +04:00
* @ param string $path
* @ return string
* does NOT work for ownClouds filesystem , use OC_FileSystem :: getMimeType instead
*/
static function getMimeType ( $path ) {
2013-08-07 18:38:57 +04:00
return self :: getMimetypeDetector () -> detect ( $path );
2012-02-16 00:44:58 +04:00
}
2012-04-14 00:59:47 +04:00
2014-04-14 19:17:50 +04:00
/**
* Get a secure mimetype that won ' t expose potential XSS .
*
* @ param string $mimeType
* @ return string
*/
static function getSecureMimeType ( $mimeType ) {
return self :: getMimetypeDetector () -> getSecureMimeType ( $mimeType );
}
2012-04-18 22:24:22 +04:00
/**
* get the mimetype form a data string
2013-08-07 18:38:57 +04:00
*
2012-09-23 04:39:11 +04:00
* @ param string $data
2012-04-18 22:24:22 +04:00
* @ return string
*/
2012-09-07 17:22:01 +04:00
static function getStringMimeType ( $data ) {
2013-08-07 18:38:57 +04:00
return self :: getMimetypeDetector () -> detectString ( $data );
2012-04-18 22:24:22 +04:00
}
2011-05-18 00:34:31 +04:00
/**
2014-05-19 19:50:53 +04:00
* Checks $_REQUEST contains a var for the $s key . If so , returns the html - escaped value of this var ; otherwise returns the default value provided by $d .
2012-09-23 04:39:11 +04:00
* @ param string $s name of the var to escape , if set .
* @ param string $d default value .
* @ return string the print - safe value .
2011-05-18 00:34:31 +04:00
*
*/
2012-04-14 00:59:47 +04:00
2011-07-28 22:10:58 +04:00
/**
2013-01-05 02:00:51 +04:00
* detect if a given program is found in the search PATH
*
2014-05-12 00:51:30 +04:00
* @ param string $name
2013-01-05 02:00:51 +04:00
* @ param bool $path
* @ internal param string $program name
* @ internal param string $optional search path , defaults to $PATH
* @ return bool true if executable program found in path
*/
2012-09-07 17:22:01 +04:00
public static function canExecute ( $name , $path = false ) {
2011-07-28 22:10:58 +04:00
// path defaults to PATH from environment if not set
if ( $path === false ) {
$path = getenv ( " PATH " );
}
// check method depends on operating system
if ( ! strncmp ( PHP_OS , " WIN " , 3 )) {
// on Windows an appropriate COM or EXE file needs to exist
$exts = array ( " .exe " , " .com " );
$check_fn = " file_exists " ;
} else {
// anywhere else we look for an executable file of that name
$exts = array ( " " );
$check_fn = " is_executable " ;
}
// Default check will be done with $path directories :
$dirs = explode ( PATH_SEPARATOR , $path );
// WARNING : We have to check if open_basedir is enabled :
$obd = ini_get ( 'open_basedir' );
2013-08-07 18:38:57 +04:00
if ( $obd != " none " ) {
2011-07-28 22:10:58 +04:00
$obd_values = explode ( PATH_SEPARATOR , $obd );
2013-08-07 18:38:57 +04:00
if ( count ( $obd_values ) > 0 and $obd_values [ 0 ]) {
2012-09-23 04:39:11 +04:00
// open_basedir is in effect !
// We need to check if the program is in one of these dirs :
$dirs = $obd_values ;
}
}
2013-08-07 18:38:57 +04:00
foreach ( $dirs as $dir ) {
foreach ( $exts as $ext ) {
if ( $check_fn ( " $dir / $name " . $ext ))
2011-07-28 22:10:58 +04:00
return true ;
}
}
return false ;
}
2012-04-14 00:59:47 +04:00
2012-02-27 15:04:04 +04:00
/**
* copy the contents of one stream to another
2013-08-07 18:38:57 +04:00
*
2012-09-23 04:39:11 +04:00
* @ param resource $source
* @ param resource $target
2013-10-14 23:33:23 +04:00
* @ return array the number of bytes copied and result
2012-02-27 15:04:04 +04:00
*/
2012-11-02 22:53:02 +04:00
public static function streamCopy ( $source , $target ) {
2013-08-07 18:38:57 +04:00
if ( ! $source or ! $target ) {
2013-10-14 23:33:23 +04:00
return array ( 0 , false );
2012-02-27 15:04:04 +04:00
}
2015-02-23 14:31:22 +03:00
$bufSize = 8192 ;
2013-02-22 19:43:11 +04:00
$result = true ;
$count = 0 ;
2013-08-07 18:38:57 +04:00
while ( ! feof ( $source )) {
2015-02-23 14:31:22 +03:00
$buf = fread ( $source , $bufSize );
$bytesWritten = fwrite ( $target , $buf );
if ( $bytesWritten !== false ) {
$count += $bytesWritten ;
}
// note: strlen is expensive so only use it when necessary,
// on the last block
if ( $bytesWritten === false
|| ( $bytesWritten < $bufSize && $bytesWritten < strlen ( $buf ))
) {
// write error, could be disk full ?
2013-02-22 17:56:50 +04:00
$result = false ;
2015-02-23 14:31:22 +03:00
break ;
2013-02-22 17:56:50 +04:00
}
2012-02-27 15:04:04 +04:00
}
2013-02-22 19:43:11 +04:00
return array ( $count , $result );
2012-02-27 15:04:04 +04:00
}
2012-04-14 00:59:47 +04:00
2012-02-28 14:16:19 +04:00
/**
* create a temporary file with an unique filename
2013-08-07 18:38:57 +04:00
*
2012-09-23 04:39:11 +04:00
* @ param string $postfix
2012-02-28 14:16:19 +04:00
* @ return string
2014-10-22 19:36:52 +04:00
* @ deprecated Use the TempManager instead
2012-02-28 14:16:19 +04:00
*
* temporary files are automatically cleaned up after the script is finished
*/
2013-08-07 18:38:57 +04:00
public static function tmpFile ( $postfix = '' ) {
2014-10-22 19:36:52 +04:00
return \OC :: $server -> getTempManager () -> getTemporaryFile ( $postfix );
2012-10-19 02:11:20 +04:00
}
2013-01-14 23:30:39 +04:00
2012-03-29 00:30:55 +04:00
/**
* create a temporary folder with an unique filename
2013-08-07 18:38:57 +04:00
*
2012-03-29 00:30:55 +04:00
* @ return string
2014-10-22 19:36:52 +04:00
* @ deprecated Use the TempManager instead
2012-03-29 00:30:55 +04:00
*
* temporary files are automatically cleaned up after the script is finished
*/
2012-09-07 17:22:01 +04:00
public static function tmpFolder () {
2014-10-22 19:36:52 +04:00
return \OC :: $server -> getTempManager () -> getTemporaryFolder ();
2012-10-19 02:11:20 +04:00
}
2012-06-14 14:57:30 +04:00
/**
2013-08-07 18:38:57 +04:00
* Adds a suffix to the name in case the file exists
*
2014-05-12 00:51:30 +04:00
* @ param string $path
* @ param string $filename
2013-08-07 18:38:57 +04:00
* @ return string
*/
2012-09-07 17:22:01 +04:00
public static function buildNotExistingFileName ( $path , $filename ) {
2013-03-08 17:22:04 +04:00
$view = \OC\Files\Filesystem :: getView ();
return self :: buildNotExistingFileNameForView ( $path , $filename , $view );
}
/**
2013-08-07 18:38:57 +04:00
* Adds a suffix to the name in case the file exists
*
2014-05-12 00:51:30 +04:00
* @ param string $path
* @ param string $filename
2013-08-07 18:38:57 +04:00
* @ return string
*/
2013-03-08 17:22:04 +04:00
public static function buildNotExistingFileNameForView ( $path , $filename , \OC\Files\View $view ) {
2013-08-07 18:38:57 +04:00
if ( $path === '/' ) {
$path = '' ;
2012-06-14 14:57:30 +04:00
}
if ( $pos = strrpos ( $filename , '.' )) {
$name = substr ( $filename , 0 , $pos );
$ext = substr ( $filename , $pos );
} else {
$name = $filename ;
2012-09-23 04:39:11 +04:00
$ext = '' ;
2012-06-14 14:57:30 +04:00
}
$newpath = $path . '/' . $filename ;
2013-07-05 17:38:09 +04:00
if ( $view -> file_exists ( $newpath )) {
2013-08-07 18:38:57 +04:00
if ( preg_match_all ( '/\((\d+)\)/' , $name , $matches , PREG_OFFSET_CAPTURE )) {
2013-09-05 13:58:57 +04:00
//Replace the last "(number)" with "(number+1)"
2013-08-07 18:38:57 +04:00
$last_match = count ( $matches [ 0 ]) - 1 ;
$counter = $matches [ 1 ][ $last_match ][ 0 ] + 1 ;
2013-07-05 17:38:09 +04:00
$offset = $matches [ 0 ][ $last_match ][ 1 ];
$match_length = strlen ( $matches [ 0 ][ $last_match ][ 0 ]);
} else {
$counter = 2 ;
$offset = false ;
}
do {
2013-08-07 18:38:57 +04:00
if ( $offset ) {
2013-09-05 13:58:57 +04:00
//Replace the last "(number)" with "(number+1)"
2013-08-07 18:38:57 +04:00
$newname = substr_replace ( $name , '(' . $counter . ')' , $offset , $match_length );
2013-07-05 17:38:09 +04:00
} else {
$newname = $name . ' (' . $counter . ')' ;
}
$newpath = $path . '/' . $newname . $ext ;
$counter ++ ;
} while ( $view -> file_exists ( $newpath ));
2012-06-14 14:57:30 +04:00
}
return $newpath ;
}
2012-07-02 22:24:26 +04:00
2013-01-13 17:54:18 +04:00
/**
2014-05-19 19:50:53 +04:00
* Checks if $sub is a subdirectory of $parent
2012-07-02 22:24:26 +04:00
*
2012-09-23 04:39:11 +04:00
* @ param string $sub
* @ param string $parent
2012-04-18 10:20:51 +04:00
* @ return bool
*/
2014-05-11 17:50:59 +04:00
public static function isSubDirectory ( $sub , $parent ) {
2014-05-11 17:49:19 +04:00
$realpathSub = realpath ( $sub );
$realpathParent = realpath ( $parent );
// realpath() may return false in case the directory does not exist
// since we can not be sure how different PHP versions may behave here
// we do an additional check whether realpath returned false
if ( $realpathSub === false || $realpathParent === false ) {
return false ;
}
// Check whether $sub is a subdirectory of $parent
if ( strpos ( $realpathSub , $realpathParent ) === 0 ) {
2013-01-13 17:33:19 +04:00
return true ;
2012-04-26 19:55:00 +04:00
}
2014-05-11 17:49:19 +04:00
2012-04-26 19:55:00 +04:00
return false ;
2012-04-18 10:20:51 +04:00
}
2012-07-02 22:24:26 +04:00
/**
2014-05-19 19:50:53 +04:00
* Returns an array with all keys from input lowercased or uppercased . Numbered indices are left as is .
2013-08-07 18:38:57 +04:00
*
* @ param array $input The array to work on
* @ param int $case Either MB_CASE_UPPER or MB_CASE_LOWER ( default )
* @ param string $encoding The encoding parameter is the character encoding . Defaults to UTF - 8
* @ return array
*
* Returns an array with all keys from input lowercased or uppercased . Numbered indices are left as is .
* based on http :// www . php . net / manual / en / function . array - change - key - case . php #107715
*
*/
2012-09-07 17:22:01 +04:00
public static function mb_array_change_key_case ( $input , $case = MB_CASE_LOWER , $encoding = 'UTF-8' ) {
2012-07-02 22:24:26 +04:00
$case = ( $case != MB_CASE_UPPER ) ? MB_CASE_LOWER : MB_CASE_UPPER ;
$ret = array ();
foreach ( $input as $k => $v ) {
$ret [ mb_convert_case ( $k , $case , $encoding )] = $v ;
}
return $ret ;
}
/**
2014-05-19 19:50:53 +04:00
* replaces a copy of string delimited by the start and ( optionally ) length parameters with the string given in replacement .
2013-01-05 02:00:51 +04:00
*
2014-05-12 00:51:30 +04:00
* @ param string $string
2013-01-05 02:00:51 +04:00
* @ param string $replacement The replacement string .
* @ param int $start If start is positive , the replacing will begin at the start 'th offset into string. If start is negative, the replacing will begin at the start' th character from the end of string .
* @ param int $length Length of the part to be replaced
* @ param string $encoding The encoding parameter is the character encoding . Defaults to UTF - 8
* @ internal param string $input The input string . . Opposite to the PHP build - in function does not accept an array .
* @ return string
*/
2012-07-02 22:24:26 +04:00
public static function mb_substr_replace ( $string , $replacement , $start , $length = null , $encoding = 'UTF-8' ) {
$start = intval ( $start );
$length = intval ( $length );
$string = mb_substr ( $string , 0 , $start , $encoding ) .
2013-01-18 23:09:03 +04:00
$replacement .
2013-08-07 18:38:57 +04:00
mb_substr ( $string , $start + $length , mb_strlen ( $string , 'UTF-8' ) - $start , $encoding );
2012-07-02 22:24:26 +04:00
return $string ;
}
/**
2014-05-19 19:50:53 +04:00
* Replace all occurrences of the search string with the replacement string
2013-08-07 18:38:57 +04:00
*
* @ param string $search The value being searched for , otherwise known as the needle .
* @ param string $replace The replacement
* @ param string $subject The string or array being searched and replaced on , otherwise known as the haystack .
* @ param string $encoding The encoding parameter is the character encoding . Defaults to UTF - 8
* @ param int $count If passed , this will be set to the number of replacements performed .
* @ return string
*
*/
2012-07-02 22:24:26 +04:00
public static function mb_str_replace ( $search , $replace , $subject , $encoding = 'UTF-8' , & $count = null ) {
$offset = - 1 ;
2012-07-20 19:51:50 +04:00
$length = mb_strlen ( $search , $encoding );
2013-08-07 18:38:57 +04:00
while (( $i = mb_strrpos ( $subject , $search , $offset , $encoding )) !== false ) {
2012-07-02 22:24:26 +04:00
$subject = OC_Helper :: mb_substr_replace ( $subject , $replace , $i , $length );
2012-10-11 14:42:57 +04:00
$offset = $i - mb_strlen ( $subject , $encoding );
2012-07-02 22:24:26 +04:00
$count ++ ;
}
return $subject ;
}
2012-07-24 12:54:56 +04:00
/**
2014-05-19 19:50:53 +04:00
* performs a search in a nested array
2013-08-07 18:38:57 +04:00
* @ param array $haystack the array to be searched
* @ param string $needle the search string
* @ param string $index optional , only search this key name
* @ return mixed the key of the matching field , otherwise false
*
* performs a search in a nested array
*
* taken from http :// www . php . net / manual / en / function . array - search . php #97645
*/
2012-07-24 12:54:56 +04:00
public static function recursiveArraySearch ( $haystack , $needle , $index = null ) {
$aIt = new RecursiveArrayIterator ( $haystack );
$it = new RecursiveIteratorIterator ( $aIt );
2013-08-07 18:38:57 +04:00
while ( $it -> valid ()) {
2012-07-24 12:54:56 +04:00
if ((( isset ( $index ) AND ( $it -> key () == $index )) OR ( ! isset ( $index ))) AND ( $it -> current () == $needle )) {
return $aIt -> key ();
}
$it -> next ();
}
return false ;
}
2012-11-12 16:56:29 +04:00
2012-11-12 17:04:23 +04:00
/**
* Shortens str to maxlen by replacing characters in the middle with '...' , eg .
* ellipsis ( 'a very long string with lots of useless info to make a better example' , 14 ) becomes 'a very ...example'
2013-08-07 18:38:57 +04:00
*
2012-11-12 17:04:23 +04:00
* @ param string $str the string
* @ param string $maxlen the maximum length of the result
* @ return string with at most maxlen characters
*/
2012-11-12 16:56:29 +04:00
public static function ellipsis ( $str , $maxlen ) {
if ( strlen ( $str ) > $maxlen ) {
$characters = floor ( $maxlen / 2 );
return substr ( $str , 0 , $characters ) . '...' . substr ( $str , - 1 * $characters );
}
return $str ;
}
2013-01-05 02:00:51 +04:00
2013-01-18 23:09:03 +04:00
/**
2014-05-19 19:50:53 +04:00
* calculates the maximum upload size respecting system settings , free space and user quota
2013-01-18 23:09:03 +04:00
*
2014-01-27 18:56:57 +04:00
* @ param string $dir the current folder where the user currently operates
2014-02-05 16:36:55 +04:00
* @ param int $freeSpace the number of bytes free on the storage holding $dir , if not set this will be received from the storage directly
* @ return int number of bytes representing
2013-01-18 23:09:03 +04:00
*/
2014-01-27 18:56:57 +04:00
public static function maxUploadFilesize ( $dir , $freeSpace = null ) {
2014-03-06 16:50:53 +04:00
if ( is_null ( $freeSpace ) || $freeSpace < 0 ){
2014-02-05 16:36:55 +04:00
$freeSpace = self :: freeSpace ( $dir );
2013-03-15 19:31:35 +04:00
}
2014-02-05 16:36:55 +04:00
return min ( $freeSpace , self :: uploadLimit ());
2013-12-08 18:59:46 +04:00
}
2012-12-20 20:16:01 +04:00
2013-12-08 18:59:46 +04:00
/**
* Calculate free space left within user quota
2014-05-19 19:50:53 +04:00
*
2014-02-05 16:36:55 +04:00
* @ param string $dir the current folder where the user currently operates
* @ return int number of bytes representing
2013-12-08 18:59:46 +04:00
*/
public static function freeSpace ( $dir ) {
$freeSpace = \OC\Files\Filesystem :: free_space ( $dir );
2014-08-19 16:05:08 +04:00
if ( $freeSpace !== \OCP\Files\FileInfo :: SPACE_UNKNOWN ) {
2013-02-16 06:27:50 +04:00
$freeSpace = max ( $freeSpace , 0 );
2013-12-08 18:59:46 +04:00
return $freeSpace ;
} else {
return INF ;
}
}
2012-12-20 20:16:01 +04:00
2013-12-08 18:59:46 +04:00
/**
* Calculate PHP upload limit
*
* @ return PHP upload file size limit
*/
public static function uploadLimit () {
$upload_max_filesize = OCP\Util :: computerFileSize ( ini_get ( 'upload_max_filesize' ));
$post_max_size = OCP\Util :: computerFileSize ( ini_get ( 'post_max_size' ));
if (( int ) $upload_max_filesize === 0 and ( int ) $post_max_size === 0 ) {
return INF ;
} elseif (( int ) $upload_max_filesize === 0 or ( int ) $post_max_size === 0 ) {
return max ( $upload_max_filesize , $post_max_size ); //only the non 0 value counts
2013-02-16 06:27:50 +04:00
} else {
2013-12-08 18:59:46 +04:00
return min ( $upload_max_filesize , $post_max_size );
2013-02-16 06:27:50 +04:00
}
2013-01-18 23:09:03 +04:00
}
2013-01-07 01:40:35 +04:00
2013-01-05 02:00:51 +04:00
/**
* Checks if a function is available
2013-08-07 18:38:57 +04:00
*
2013-01-05 02:00:51 +04:00
* @ param string $function_name
* @ return bool
*/
public static function is_function_enabled ( $function_name ) {
if ( ! function_exists ( $function_name )) {
return false ;
}
2014-01-07 17:53:02 +04:00
$disabled = explode ( ',' , ini_get ( 'disable_functions' ));
2014-01-07 22:47:01 +04:00
$disabled = array_map ( 'trim' , $disabled );
2013-01-05 02:00:51 +04:00
if ( in_array ( $function_name , $disabled )) {
return false ;
}
2014-01-07 22:47:01 +04:00
$disabled = explode ( ',' , ini_get ( 'suhosin.executor.func.blacklist' ));
$disabled = array_map ( 'trim' , $disabled );
2013-01-05 02:00:51 +04:00
if ( in_array ( $function_name , $disabled )) {
return false ;
}
return true ;
}
2013-01-06 15:18:21 +04:00
2014-11-20 14:37:59 +03:00
/**
* Try to find a program
* Note : currently windows is not supported
*
* @ param string $program
* @ return null | string
*/
public static function findBinaryPath ( $program ) {
2015-01-09 16:13:02 +03:00
$memcache = \OC :: $server -> getMemCacheFactory () -> create ( 'findBinaryPath' );
if ( $memcache -> hasKey ( $program )) {
return $memcache -> get ( $program );
}
$result = null ;
2014-11-20 14:37:59 +03:00
if ( ! \OC_Util :: runningOnWindows () && self :: is_function_enabled ( 'exec' )) {
exec ( 'command -v ' . escapeshellarg ( $program ) . ' 2> /dev/null' , $output , $returnCode );
if ( $returnCode === 0 && count ( $output ) > 0 ) {
2015-01-09 16:13:02 +03:00
$result = escapeshellcmd ( $output [ 0 ]);
2014-11-20 14:37:59 +03:00
}
}
2015-01-09 16:13:02 +03:00
$memcache -> set ( $program , $result , 3600 );
return $result ;
2014-11-20 14:37:59 +03:00
}
2013-01-02 17:35:45 +04:00
/**
2013-08-27 02:59:58 +04:00
* Calculate the disc space for the given path
*
* @ param string $path
2014-04-02 19:10:57 +04:00
* @ param \OCP\Files\FileInfo $rootInfo ( optional )
2013-08-27 02:59:58 +04:00
* @ return array
2013-01-02 17:35:45 +04:00
*/
2014-04-02 19:10:57 +04:00
public static function getStorageInfo ( $path , $rootInfo = null ) {
2013-11-18 20:29:30 +04:00
// return storage info without adding mount points
2014-03-25 19:37:46 +04:00
$includeExtStorage = \OC_Config :: getValue ( 'quota_include_external_storage' , false );
2014-04-29 17:14:48 +04:00
if ( ! $rootInfo ) {
2014-04-02 19:10:57 +04:00
$rootInfo = \OC\Files\Filesystem :: getFileInfo ( $path , false );
}
2015-01-06 17:56:06 +03:00
if ( ! $rootInfo instanceof \OCP\Files\FileInfo ) {
throw new \OCP\Files\NotFoundException ();
}
2014-04-02 19:10:57 +04:00
$used = $rootInfo -> getSize ();
2013-01-02 17:35:45 +04:00
if ( $used < 0 ) {
$used = 0 ;
}
2014-03-10 18:19:18 +04:00
$quota = 0 ;
$storage = $rootInfo -> getStorage ();
2014-03-25 19:37:46 +04:00
if ( $includeExtStorage && $storage -> instanceOfStorage ( '\OC\Files\Storage\Shared' )) {
$includeExtStorage = false ;
}
if ( $includeExtStorage ) {
$quota = OC_Util :: getUserQuota ( \OCP\User :: getUser ());
2014-08-19 16:05:08 +04:00
if ( $quota !== \OCP\Files\FileInfo :: SPACE_UNLIMITED ) {
2014-03-25 19:37:46 +04:00
// always get free space / total space from root + mount points
$path = '' ;
return self :: getGlobalStorageInfo ();
}
}
// TODO: need a better way to get total space from storage
2014-06-02 23:52:31 +04:00
if ( $storage -> instanceOfStorage ( '\OC\Files\Storage\Wrapper\Quota' )) {
2014-03-10 18:19:18 +04:00
$quota = $storage -> getQuota ();
}
$free = $storage -> free_space ( '' );
2013-08-07 18:38:57 +04:00
if ( $free >= 0 ) {
2013-03-15 19:46:20 +04:00
$total = $free + $used ;
} else {
$total = $free ; //either unknown or unlimited
}
2013-08-27 12:58:17 +04:00
if ( $total > 0 ) {
2014-03-10 18:19:18 +04:00
if ( $quota > 0 && $total > $quota ) {
$total = $quota ;
}
2013-08-27 12:58:17 +04:00
// prevent division by zero or error codes (negative values)
2013-03-15 19:46:20 +04:00
$relative = round (( $used / $total ) * 10000 ) / 100 ;
} else {
$relative = 0 ;
}
2013-01-02 17:35:45 +04:00
return array ( 'free' => $free , 'used' => $used , 'total' => $total , 'relative' => $relative );
}
2014-03-25 19:37:46 +04:00
/**
* Get storage info including all mount points and quota
*
* @ return array
*/
private static function getGlobalStorageInfo () {
$quota = OC_Util :: getUserQuota ( \OCP\User :: getUser ());
$rootInfo = \OC\Files\Filesystem :: getFileInfo ( '' , 'ext' );
$used = $rootInfo [ 'size' ];
if ( $used < 0 ) {
$used = 0 ;
}
$total = $quota ;
$free = $quota - $used ;
if ( $total > 0 ) {
if ( $quota > 0 && $total > $quota ) {
$total = $quota ;
}
// prevent division by zero or error codes (negative values)
$relative = round (( $used / $total ) * 10000 ) / 100 ;
} else {
$relative = 0 ;
}
return array ( 'free' => $free , 'used' => $used , 'total' => $total , 'relative' => $relative );
}
2014-11-25 18:12:12 +03:00
/**
* Returns whether the config file is set manually to read - only
* @ return bool
*/
public static function isReadOnlyConfigEnabled () {
return \OC :: $server -> getConfig () -> getSystemValue ( 'config_is_read_only' , false );
}
2011-03-03 00:18:22 +03:00
}