2011-07-27 21:07:28 +04:00
< ? php
/**
2015-03-26 13:44:34 +03:00
* @ author Adam Williamson < awilliam @ redhat . com >
* @ author Andreas Fischer < bantu @ owncloud . com >
* @ author Arthur Schiwon < blizzz @ owncloud . com >
* @ author Bart Visscher < bartv @ thisnet . nl >
* @ author Bernhard Posselt < dev @ bernhard - posselt . com >
* @ author Birk Borkason < daniel . niccoli @ gmail . com >
* @ author Björn Schießle < schiessle @ owncloud . com >
* @ author Brice Maron < brice @ bmaron . net >
* @ author Christian Reiner < github @ christian - reiner . info >
* @ author Christopher Schäpers < kondou @ ts . unde . re >
* @ author Clark Tomlinson < fallen013 @ gmail . com >
2015-06-25 12:43:55 +03:00
* @ author cmeh < cmeh @ users . noreply . github . com >
2015-03-26 13:44:34 +03:00
* @ author Florin Peter < github @ florin - peter . de >
* @ author Frank Karlitschek < frank @ owncloud . org >
* @ author Georg Ehrke < georg @ owncloud . com >
* @ author helix84 < helix84 @ centrum . sk >
* @ author Jakob Sack < mail @ jakobsack . de >
* @ author Joas Schilling < nickvergessen @ owncloud . com >
* @ author Jörn Friedrich Dreyer < jfd @ butonic . de >
* @ author Lukas Reschke < lukas @ owncloud . com >
* @ author Markus Goetz < markus @ woboq . com >
* @ author Marvin Thomas Rabe < mrabe @ marvinrabe . de >
* @ author Michael Gapczynski < GapczynskiM @ gmail . com >
* @ author Michael Göhler < somebody . here @ gmx . de >
* @ author Morris Jobke < hey @ morrisjobke . de >
* @ author Robin Appelman < icewind @ owncloud . com >
* @ author Robin McCorkell < rmccorkell @ karoshi . org . uk >
* @ author Scrutinizer Auto - Fixer < auto - fixer @ scrutinizer - ci . com >
* @ author Stefan Rado < owncloud @ sradonia . net >
* @ author Thomas Müller < thomas . mueller @ tmit . eu >
* @ author Thomas Schmidt < tschmidt @ suse . de >
* @ author Thomas Tanghus < thomas @ tanghus . net >
* @ author Victor Dubiniuk < dubiniuk @ owncloud . com >
* @ author Vincent Petry < pvince81 @ owncloud . com >
* @ author Volkan Gezer < volkangezer @ gmail . com >
*
* @ copyright Copyright ( c ) 2015 , ownCloud , Inc .
* @ 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 < http :// www . gnu . org / licenses />
2011-07-27 21:07:28 +04:00
*
*/
2011-07-29 23:36:03 +04:00
class OC_Util {
2014-08-19 20:01:26 +04:00
public static $scripts = array ();
public static $styles = array ();
public static $headers = array ();
private static $rootMounted = false ;
private static $fsSetup = false ;
2011-07-27 21:07:28 +04:00
2015-02-18 16:24:50 +03:00
protected static function getAppManager () {
return \OC :: $server -> getAppManager ();
}
2014-04-25 16:34:47 +04:00
private static function initLocalStorageRootFS () {
// mount local file backend as root
2014-08-19 20:01:26 +04:00
$configDataDirectory = OC_Config :: getValue ( " datadirectory " , OC :: $SERVERROOT . " /data " );
2014-04-25 16:34:47 +04:00
//first set up the local "root" storage
2015-04-02 14:28:36 +03:00
\OC\Files\Filesystem :: initMountManager ();
2014-08-19 20:01:26 +04:00
if ( ! self :: $rootMounted ) {
\OC\Files\Filesystem :: mount ( '\OC\Files\Storage\Local' , array ( 'datadir' => $configDataDirectory ), '/' );
2014-04-25 16:34:47 +04:00
self :: $rootMounted = true ;
}
}
2014-07-23 18:42:33 +04:00
2014-04-25 16:34:47 +04:00
/**
* mounting an object storage as the root fs will in essence remove the
* necessity of a data folder being present .
* TODO make home storage aware of this and use the object storage instead of local disk access
2014-08-19 20:01:26 +04:00
*
2014-04-25 16:34:47 +04:00
* @ param array $config containing 'class' and optional 'arguments'
*/
2014-06-11 15:55:11 +04:00
private static function initObjectStoreRootFS ( $config ) {
2014-04-25 16:34:47 +04:00
// check misconfiguration
if ( empty ( $config [ 'class' ])) {
2014-06-18 00:06:56 +04:00
\OCP\Util :: writeLog ( 'files' , 'No class given for objectstore' , \OCP\Util :: ERROR );
2014-04-25 16:34:47 +04:00
}
if ( ! isset ( $config [ 'arguments' ])) {
$config [ 'arguments' ] = array ();
}
2014-06-18 00:06:56 +04:00
// instantiate object store implementation
$config [ 'arguments' ][ 'objectstore' ] = new $config [ 'class' ]( $config [ 'arguments' ]);
// mount with plain / root object store implementation
$config [ 'class' ] = '\OC\Files\ObjectStore\ObjectStoreStorage' ;
2014-04-25 16:34:47 +04:00
// mount object storage as root
2015-04-02 14:28:36 +03:00
\OC\Files\Filesystem :: initMountManager ();
2014-08-19 20:01:26 +04:00
if ( ! self :: $rootMounted ) {
2014-04-25 16:34:47 +04:00
\OC\Files\Filesystem :: mount ( $config [ 'class' ], $config [ 'arguments' ], '/' );
self :: $rootMounted = true ;
}
}
2014-07-23 18:42:33 +04:00
2013-08-15 10:49:19 +04:00
/**
2014-05-19 19:50:53 +04:00
* Can be set up
2014-08-19 20:01:26 +04:00
*
2013-08-23 09:30:42 +04:00
* @ param string $user
2013-08-15 10:49:19 +04:00
* @ return boolean
2013-08-18 12:33:09 +04:00
* @ description configure the initial filesystem based on the configuration
2013-08-15 10:49:19 +04:00
*/
2014-08-19 20:01:26 +04:00
public static function setupFS ( $user = '' ) {
2013-08-18 12:33:09 +04:00
//setting up the filesystem twice can only lead to trouble
2014-08-19 20:01:26 +04:00
if ( self :: $fsSetup ) {
2011-07-27 21:07:28 +04:00
return false ;
}
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> start ( 'setup_fs' , 'Setup filesystem' );
2012-08-29 23:35:55 +04:00
// If we are not forced to load a specific user we load the one that is logged in
2014-08-19 20:01:26 +04:00
if ( $user == " " && OC_User :: isLoggedIn ()) {
2012-08-29 23:35:55 +04:00
$user = OC_User :: getUser ();
}
2012-10-28 16:47:53 +04:00
// load all filesystem apps before, so no setup-hook gets lost
2014-02-06 13:04:18 +04:00
OC_App :: loadApps ( array ( 'filesystem' ));
2012-10-28 16:47:53 +04:00
2012-08-29 23:35:55 +04:00
// the filesystem will finish when $user is not empty,
// mark fs setup here to avoid doing the setup from loading
// OC_Filesystem
if ( $user != '' ) {
2014-08-19 20:01:26 +04:00
self :: $fsSetup = true ;
2012-08-29 23:35:55 +04:00
}
2015-04-02 14:28:36 +03:00
\OC\Files\Filesystem :: initMountManager ();
2015-04-01 18:12:06 +03:00
\OC\Files\Filesystem :: addStorageWrapper ( 'mount_options' , function ( $mountPoint , \OCP\Files\Storage $storage , \OCP\Files\Mount\IMountPoint $mount ) {
if ( $storage -> instanceOfStorage ( '\OC\Files\Storage\Common' )) {
/** @var \OC\Files\Storage\Common $storage */
$storage -> setMountOptions ( $mount -> getOptions ());
}
return $storage ;
});
2015-01-24 00:53:21 +03:00
// install storage availability wrapper, before most other wrappers
\OC\Files\Filesystem :: addStorageWrapper ( 'oc_availability' , function ( $mountPoint , $storage ) {
if ( ! $storage -> isLocal ()) {
return new \OC\Files\Storage\Wrapper\Availability ([ 'storage' => $storage ]);
}
return $storage ;
});
2015-04-01 18:12:06 +03:00
\OC\Files\Filesystem :: addStorageWrapper ( 'oc_quota' , function ( $mountPoint , $storage ) {
// set up quota for home storages, even for other users
// which can happen when using sharing
/**
* @ var \OC\Files\Storage\Storage $storage
*/
if ( $storage -> instanceOfStorage ( '\OC\Files\Storage\Home' )
|| $storage -> instanceOfStorage ( '\OC\Files\ObjectStore\HomeObjectStoreStorage' )
) {
/** @var \OC\Files\Storage\Home $storage */
if ( is_object ( $storage -> getUser ())) {
$user = $storage -> getUser () -> getUID ();
$quota = OC_Util :: getUserQuota ( $user );
if ( $quota !== \OCP\Files\FileInfo :: SPACE_UNLIMITED ) {
return new \OC\Files\Storage\Wrapper\Quota ( array ( 'storage' => $storage , 'quota' => $quota , 'root' => 'files' ));
}
}
}
return $storage ;
});
OC_Hook :: emit ( 'OC_Filesystem' , 'preSetup' , array ( 'user' => $user ));
2014-04-25 16:34:47 +04:00
//check if we are using an object storage
2014-08-19 20:01:26 +04:00
$objectStore = OC_Config :: getValue ( 'objectstore' );
if ( isset ( $objectStore )) {
2014-06-13 17:49:40 +04:00
self :: initObjectStoreRootFS ( $objectStore );
2014-04-25 16:34:47 +04:00
} else {
self :: initLocalStorageRootFS ();
2012-02-06 02:49:22 +04:00
}
2012-06-20 10:57:21 +04:00
2014-01-21 14:32:30 +04:00
if ( $user != '' && ! OCP\User :: userExists ( $user )) {
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> end ( 'setup_fs' );
2014-01-21 14:32:30 +04:00
return false ;
}
2013-08-23 09:30:42 +04:00
//if we aren't logged in, there is no use to set up the filesystem
2014-08-19 20:01:26 +04:00
if ( $user != " " ) {
2013-11-06 14:57:04 +04:00
2014-08-19 20:01:26 +04:00
$userDir = '/' . $user . '/files' ;
2014-06-13 17:49:40 +04:00
2012-08-27 17:55:22 +04:00
//jail the user into his "home" directory
2013-08-15 10:49:19 +04:00
\OC\Files\Filesystem :: init ( $user , $userDir );
2012-10-23 18:16:46 +04:00
2013-08-15 10:49:19 +04:00
OC_Hook :: emit ( 'OC_Filesystem' , 'setup' , array ( 'user' => $user , 'user_dir' => $userDir ));
2011-07-27 21:07:28 +04:00
}
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> end ( 'setup_fs' );
2012-10-26 20:29:24 +04:00
return true ;
2011-07-27 21:07:28 +04:00
}
2014-05-12 14:19:07 +04:00
/**
2014-05-19 19:50:53 +04:00
* check if a password is required for each public link
2014-08-19 20:01:26 +04:00
*
2014-05-12 14:19:07 +04:00
* @ return boolean
*/
public static function isPublicLinkPasswordRequired () {
$appConfig = \OC :: $server -> getAppConfig ();
$enforcePassword = $appConfig -> getValue ( 'core' , 'shareapi_enforce_links_password' , 'no' );
return ( $enforcePassword === 'yes' ) ? true : false ;
}
2014-05-13 17:22:18 +04:00
/**
* check if sharing is disabled for the current user
*
* @ return boolean
*/
public static function isSharingDisabledForUser () {
2015-07-03 15:16:29 +03:00
if ( \OC :: $server -> getAppConfig () -> getValue ( 'core' , 'shareapi_exclude_groups' , 'no' ) === 'yes' ) {
2014-05-13 17:22:18 +04:00
$user = \OCP\User :: getUser ();
2015-07-03 15:16:29 +03:00
$groupsList = \OC :: $server -> getAppConfig () -> getValue ( 'core' , 'shareapi_exclude_groups_list' , '' );
2014-05-13 17:22:18 +04:00
$excludedGroups = explode ( ',' , $groupsList );
$usersGroups = \OC_Group :: getUserGroups ( $user );
if ( ! empty ( $usersGroups )) {
$remainingGroups = array_diff ( $usersGroups , $excludedGroups );
// if the user is only in groups which are disabled for sharing then
// sharing is also disabled for the user
if ( empty ( $remainingGroups )) {
return true ;
}
}
}
return false ;
}
2014-07-23 18:42:33 +04:00
/**
* check if share API enforces a default expire date
2014-08-19 20:01:26 +04:00
*
2014-07-23 18:42:33 +04:00
* @ return boolean
*/
public static function isDefaultExpireDateEnforced () {
$isDefaultExpireDateEnabled = \OCP\Config :: getAppValue ( 'core' , 'shareapi_default_expire_date' , 'no' );
$enforceDefaultExpireDate = false ;
if ( $isDefaultExpireDateEnabled === 'yes' ) {
$value = \OCP\Config :: getAppValue ( 'core' , 'shareapi_enforce_expire_date' , 'no' );
$enforceDefaultExpireDate = ( $value === 'yes' ) ? true : false ;
}
return $enforceDefaultExpireDate ;
}
2014-02-06 19:30:58 +04:00
/**
2014-04-21 17:44:54 +04:00
* Get the quota of a user
2014-08-19 20:01:26 +04:00
*
2014-02-06 19:30:58 +04:00
* @ param string $user
2014-04-21 17:44:54 +04:00
* @ return int Quota bytes
2014-02-06 19:30:58 +04:00
*/
2014-08-19 20:01:26 +04:00
public static function getUserQuota ( $user ) {
2014-02-13 19:28:49 +04:00
$config = \OC :: $server -> getConfig ();
$userQuota = $config -> getUserValue ( $user , 'files' , 'quota' , 'default' );
2014-08-19 20:01:26 +04:00
if ( $userQuota === 'default' ) {
2014-02-13 19:28:49 +04:00
$userQuota = $config -> getAppValue ( 'files' , 'default_quota' , 'none' );
2013-07-25 18:01:37 +04:00
}
if ( $userQuota === 'none' ) {
2014-08-19 18:45:22 +04:00
return \OCP\Files\FileInfo :: SPACE_UNLIMITED ;
2013-07-25 18:01:37 +04:00
} else {
return OC_Helper :: computerFileSize ( $userQuota );
}
}
2013-10-04 01:22:11 +04:00
/**
2014-08-29 16:36:00 +04:00
* copies the skeleton to the users / files
2014-08-19 20:01:26 +04:00
*
2015-06-16 17:02:30 +03:00
* @ param String $userId
2014-08-29 16:36:00 +04:00
* @ param \OCP\Files\Folder $userDirectory
2013-10-04 01:22:11 +04:00
*/
2015-06-16 17:02:30 +03:00
public static function copySkeleton ( $userId , \OCP\Files\Folder $userDirectory ) {
2014-08-29 16:36:00 +04:00
$skeletonDirectory = \OCP\Config :: getSystemValue ( 'skeletondirectory' , \OC :: $SERVERROOT . '/core/skeleton' );
2014-08-16 03:07:42 +04:00
if ( ! empty ( $skeletonDirectory )) {
2014-08-29 16:36:00 +04:00
\OCP\Util :: writeLog (
'files_skeleton' ,
2015-06-16 17:02:30 +03:00
'copying skeleton for ' . $userId . ' from ' . $skeletonDirectory . ' to ' . $userDirectory -> getFullPath ( '/' ),
2014-08-29 16:36:00 +04:00
\OCP\Util :: DEBUG
);
self :: copyr ( $skeletonDirectory , $userDirectory );
// update the file cache
$userDirectory -> getStorage () -> getScanner () -> scan ( '' , \OC\Files\Cache\Scanner :: SCAN_RECURSIVE );
2014-08-16 03:07:42 +04:00
}
2013-10-04 01:22:11 +04:00
}
/**
2014-08-29 16:36:00 +04:00
* copies a directory recursively by using streams
2014-08-19 20:01:26 +04:00
*
2013-10-04 01:22:11 +04:00
* @ param string $source
2014-08-29 16:36:00 +04:00
* @ param \OCP\Files\Folder $target
2013-10-04 01:22:11 +04:00
* @ return void
*/
2014-08-29 16:36:00 +04:00
public static function copyr ( $source , \OCP\Files\Folder $target ) {
2013-10-04 01:22:11 +04:00
$dir = opendir ( $source );
2014-08-19 20:01:26 +04:00
while ( false !== ( $file = readdir ( $dir ))) {
if ( ! \OC\Files\Filesystem :: isIgnoredDir ( $file )) {
if ( is_dir ( $source . '/' . $file )) {
2014-08-29 16:36:00 +04:00
$child = $target -> newFolder ( $file );
self :: copyr ( $source . '/' . $file , $child );
2013-10-04 01:22:11 +04:00
} else {
2014-08-29 16:36:00 +04:00
$child = $target -> newFile ( $file );
stream_copy_to_stream ( fopen ( $source . '/' . $file , 'r' ), $child -> fopen ( 'w' ));
2013-10-04 01:22:11 +04:00
}
}
}
closedir ( $dir );
}
2013-08-15 10:49:19 +04:00
/**
* @ return void
2013-08-18 12:33:09 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function tearDownFS () {
2012-10-10 15:18:36 +04:00
\OC\Files\Filesystem :: tearDown ();
2014-08-19 20:01:26 +04:00
self :: $fsSetup = false ;
self :: $rootMounted = false ;
2011-07-27 21:07:28 +04:00
}
2012-10-28 16:45:37 +04:00
2011-07-27 21:07:28 +04:00
/**
2014-05-19 19:50:53 +04:00
* get the current installed version of ownCloud
2014-08-19 20:01:26 +04:00
*
2011-07-27 21:07:28 +04:00
* @ return array
*/
2012-09-07 17:22:01 +04:00
public static function getVersion () {
2013-09-28 01:41:24 +04:00
OC_Util :: loadVersion ();
2013-09-30 22:28:00 +04:00
return \OC :: $server -> getSession () -> get ( 'OC_Version' );
2011-09-28 15:52:26 +04:00
}
/**
2014-05-19 19:50:53 +04:00
* get the current installed version string of ownCloud
2014-08-19 20:01:26 +04:00
*
2011-09-28 15:52:26 +04:00
* @ return string
*/
2012-09-07 17:22:01 +04:00
public static function getVersionString () {
2013-09-28 01:41:24 +04:00
OC_Util :: loadVersion ();
2013-09-30 22:28:00 +04:00
return \OC :: $server -> getSession () -> get ( 'OC_VersionString' );
2011-07-27 21:07:28 +04:00
}
2012-07-24 02:39:59 +04:00
/**
2013-08-15 10:49:19 +04:00
* @ description get the current installed edition of ownCloud . There is the community
2013-02-11 20:44:02 +04:00
* edition that just returns an empty string and the enterprise edition
* that returns " Enterprise " .
2012-07-24 02:39:59 +04:00
* @ return string
*/
2012-09-07 17:22:01 +04:00
public static function getEditionString () {
2014-12-25 11:48:15 +03:00
if ( OC_App :: isEnabled ( 'enterprise_key' )) {
return " Enterprise " ;
} else {
return " " ;
}
2013-09-28 01:41:24 +04:00
}
/**
* @ description get the update channel of the current installed of ownCloud .
* @ return string
*/
public static function getChannel () {
OC_Util :: loadVersion ();
2013-09-30 22:28:00 +04:00
return \OC :: $server -> getSession () -> get ( 'OC_Channel' );
2013-09-28 01:41:24 +04:00
}
2013-10-02 12:11:18 +04:00
2013-09-28 01:41:24 +04:00
/**
* @ description get the build number of the current installed of ownCloud .
* @ return string
*/
public static function getBuild () {
OC_Util :: loadVersion ();
2013-09-30 22:28:00 +04:00
return \OC :: $server -> getSession () -> get ( 'OC_Build' );
2013-09-28 01:41:24 +04:00
}
/**
* @ description load the version . php into the session as cache
*/
private static function loadVersion () {
2014-08-19 20:01:26 +04:00
$timestamp = filemtime ( OC :: $SERVERROOT . '/version.php' );
if ( ! \OC :: $server -> getSession () -> exists ( 'OC_Version' ) or OC :: $server -> getSession () -> get ( 'OC_Version_Timestamp' ) != $timestamp ) {
2015-03-09 10:02:09 +03:00
require OC :: $SERVERROOT . '/version.php' ;
2013-09-30 22:28:00 +04:00
$session = \OC :: $server -> getSession ();
2013-10-05 14:50:36 +04:00
/** @var $timestamp int */
$session -> set ( 'OC_Version_Timestamp' , $timestamp );
2013-09-30 22:28:00 +04:00
/** @var $OC_Version string */
$session -> set ( 'OC_Version' , $OC_Version );
/** @var $OC_VersionString string */
$session -> set ( 'OC_VersionString' , $OC_VersionString );
/** @var $OC_Build string */
$session -> set ( 'OC_Build' , $OC_Build );
2015-05-13 20:00:46 +03:00
// Allow overriding update channel
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'installed' , false )) {
$channel = \OC :: $server -> getAppConfig () -> getValue ( 'core' , 'OC_Channel' );
} else {
2015-05-27 17:42:24 +03:00
/** @var $OC_Channel string */
2015-05-13 20:00:46 +03:00
$channel = $OC_Channel ;
}
if ( ! is_null ( $channel )) {
$session -> set ( 'OC_Channel' , $channel );
} else {
/** @var $OC_Channel string */
$session -> set ( 'OC_Channel' , $OC_Channel );
}
2013-09-28 01:41:24 +04:00
}
2012-07-24 02:39:59 +04:00
}
2012-04-01 13:20:12 +04:00
2011-07-27 21:07:28 +04:00
/**
2014-11-03 13:18:17 +03:00
* generates a path for JS / CSS files . If no application is provided it will create the path for core .
2011-07-27 21:07:28 +04:00
*
2014-12-10 17:41:38 +03:00
* @ param string $application application to get the files from
* @ param string $directory directory withing this application ( css , js , vendor , etc )
* @ param string $file the file inside of the above folder
2014-11-03 13:18:17 +03:00
* @ return string the path
2011-07-27 21:07:28 +04:00
*/
2014-11-03 13:18:17 +03:00
private static function generatePath ( $application , $directory , $file ) {
2014-08-19 20:01:26 +04:00
if ( is_null ( $file )) {
2011-07-27 21:07:28 +04:00
$file = $application ;
$application = " " ;
}
2014-08-19 20:01:26 +04:00
if ( ! empty ( $application )) {
2014-11-03 13:18:17 +03:00
return " $application / $directory / $file " ;
2013-08-15 10:49:19 +04:00
} else {
2014-11-03 13:18:17 +03:00
return " $directory / $file " ;
2011-07-27 21:07:28 +04:00
}
}
2014-11-03 13:18:17 +03:00
/**
* add a javascript file
*
* @ param string $application application id
* @ param string | null $file filename
2015-09-17 10:14:04 +03:00
* @ param bool $prepend prepend the Script to the beginning of the list
2014-11-03 13:18:17 +03:00
* @ return void
*/
2015-09-17 10:14:04 +03:00
public static function addScript ( $application , $file = null , $prepend = false ) {
2014-12-10 17:41:38 +03:00
$path = OC_Util :: generatePath ( $application , 'js' , $file );
2015-09-25 12:58:12 +03:00
//TODO eliminate double code
2014-12-10 17:41:38 +03:00
if ( ! in_array ( $path , self :: $scripts )) {
2015-01-14 17:27:37 +03:00
// core js files need separate handling
if ( $application !== 'core' && $file !== null ) {
self :: addTranslations ( $application );
}
2015-09-17 10:14:04 +03:00
if ( $prepend === true ) {
array_unshift ( self :: $scripts , $path );
}
else {
self :: $scripts [] = $path ;
}
2014-12-10 17:41:38 +03:00
}
2014-11-03 13:18:17 +03:00
}
/**
* add a javascript file from the vendor sub folder
*
* @ param string $application application id
* @ param string | null $file filename
2015-09-17 10:14:04 +03:00
* @ param bool $prepend prepend the Script to the beginning of the list
2014-11-03 13:18:17 +03:00
* @ return void
*/
2015-09-17 10:14:04 +03:00
public static function addVendorScript ( $application , $file = null , $prepend = false ) {
2014-12-10 17:41:38 +03:00
$path = OC_Util :: generatePath ( $application , 'vendor' , $file );
2015-09-25 12:58:12 +03:00
//TODO eliminate double code
2015-09-17 10:14:04 +03:00
if ( ! in_array ( $path , self :: $scripts )) {
if ( $prepend === true ) {
array_unshift ( self :: $scripts , $path );
} else {
self :: $scripts [] = $path ;
}
2014-12-10 17:41:38 +03:00
}
2014-11-03 13:18:17 +03:00
}
2014-10-17 21:47:37 +04:00
/**
* add a translation JS file
*
* @ param string $application application id
* @ param string $languageCode language code , defaults to the current language
2015-09-17 10:14:04 +03:00
* @ param bool $prepend prepend the Script to the beginning of the list
2014-10-17 21:47:37 +04:00
*/
2015-09-17 10:14:04 +03:00
public static function addTranslations ( $application , $languageCode = null , $prepend = false ) {
2014-10-17 21:47:37 +04:00
if ( is_null ( $languageCode )) {
2015-03-02 20:01:51 +03:00
$languageCode = \OC_L10N :: findLanguage ( $application );
2014-10-17 21:47:37 +04:00
}
if ( ! empty ( $application )) {
2014-12-10 17:41:38 +03:00
$path = " $application /l10n/ $languageCode " ;
2014-10-17 21:47:37 +04:00
} else {
2014-12-10 17:41:38 +03:00
$path = " l10n/ $languageCode " ;
}
2015-09-25 12:58:12 +03:00
//TODO eliminate double code
2014-12-10 17:41:38 +03:00
if ( ! in_array ( $path , self :: $scripts )) {
2015-09-17 10:14:04 +03:00
if ( $prepend === true ) {
array_unshift ( self :: $scripts , $path );
} else {
self :: $scripts [] = $path ;
}
2014-10-17 21:47:37 +04:00
}
}
2011-07-27 21:07:28 +04:00
/**
2014-05-19 19:50:53 +04:00
* add a css file
2011-07-27 21:07:28 +04:00
*
2014-10-17 21:47:37 +04:00
* @ param string $application application id
2014-02-19 12:31:54 +04:00
* @ param string | null $file filename
2015-09-25 12:56:55 +03:00
* @ param bool $prepend prepend the Style to the beginning of the list
2013-08-15 10:49:19 +04:00
* @ return void
2011-07-27 21:07:28 +04:00
*/
2015-09-25 12:56:55 +03:00
public static function addStyle ( $application , $file = null , $prepend = false ) {
2014-12-10 17:41:38 +03:00
$path = OC_Util :: generatePath ( $application , 'css' , $file );
2015-09-25 12:58:12 +03:00
//TODO eliminate double code
2014-12-10 17:41:38 +03:00
if ( ! in_array ( $path , self :: $styles )) {
2015-09-25 12:56:55 +03:00
if ( $prepend === true ) {
array_unshift ( self :: $styles , $path );
} else {
self :: $styles [] = $path ;
}
2014-12-10 17:41:38 +03:00
}
2014-11-03 13:18:17 +03:00
}
/**
* add a css file from the vendor sub folder
*
* @ param string $application application id
* @ param string | null $file filename
2015-09-25 12:56:55 +03:00
* @ param bool $prepend prepend the Style to the beginning of the list
2014-11-03 13:18:17 +03:00
* @ return void
*/
2015-09-25 12:56:55 +03:00
public static function addVendorStyle ( $application , $file = null , $prepend = false ) {
2014-12-10 17:41:38 +03:00
$path = OC_Util :: generatePath ( $application , 'vendor' , $file );
2015-09-25 12:58:12 +03:00
//TODO eliminate double code
2014-12-10 17:41:38 +03:00
if ( ! in_array ( $path , self :: $styles )) {
2015-09-25 12:56:55 +03:00
if ( $prepend === true ) {
array_unshift ( self :: $styles , $path );
} else {
self :: $styles [] = $path ;
}
2014-12-10 17:41:38 +03:00
}
2011-07-27 21:07:28 +04:00
}
/**
2014-05-19 19:50:53 +04:00
* Add a custom element to the header
2014-10-28 13:15:58 +03:00
* If $text is null then the element will be written as empty element .
* So use " " to get a closing tag .
2013-08-23 09:30:42 +04:00
* @ param string $tag tag name of the element
2012-02-08 01:33:01 +04:00
* @ param array $attributes array of attributes for the element
2011-07-27 21:07:28 +04:00
* @ param string $text the text content for the element
*/
2014-10-28 13:15:58 +03:00
public static function addHeader ( $tag , $attributes , $text = null ) {
2013-08-15 10:49:19 +04:00
self :: $headers [] = array (
2014-08-19 20:01:26 +04:00
'tag' => $tag ,
'attributes' => $attributes ,
'text' => $text
2013-08-15 10:49:19 +04:00
);
2011-07-27 21:07:28 +04:00
}
2012-07-24 02:39:59 +04:00
/**
2014-05-19 19:50:53 +04:00
* formats a timestamp in the " right " way
2012-07-24 02:39:59 +04:00
*
2013-08-23 09:30:42 +04:00
* @ param int $timestamp
* @ param bool $dateOnly option to omit time from the result
2014-09-22 17:03:28 +04:00
* @ param DateTimeZone | string $timeZone where the given timestamp shall be converted to
2013-08-15 10:49:19 +04:00
* @ return string timestamp
2014-11-24 18:37:04 +03:00
*
* @ deprecated Use \OC :: $server -> query ( 'DateTimeFormatter' ) instead
2012-07-24 02:39:59 +04:00
*/
2014-09-22 17:03:28 +04:00
public static function formatDate ( $timestamp , $dateOnly = false , $timeZone = null ) {
2014-11-24 18:37:04 +03:00
if ( $timeZone !== null && ! $timeZone instanceof \DateTimeZone ) {
$timeZone = new \DateTimeZone ( $timeZone );
2012-04-16 14:21:12 +04:00
}
2014-11-24 18:37:04 +03:00
/** @var \OC\DateTimeFormatter $formatter */
$formatter = \OC :: $server -> query ( 'DateTimeFormatter' );
if ( $dateOnly ) {
return $formatter -> formatDate ( $timestamp , 'long' , $timeZone );
}
return $formatter -> formatDateTime ( $timestamp , 'long' , 'long' , $timeZone );
2011-07-27 21:07:28 +04:00
}
/**
2014-05-19 19:50:53 +04:00
* check if the current server configuration is suitable for ownCloud
2014-08-19 20:01:26 +04:00
*
2014-09-08 16:56:11 +04:00
* @ param \OCP\IConfig $config
2011-07-27 21:07:28 +04:00
* @ return array arrays with error messages and hints
*/
2014-10-24 16:13:40 +04:00
public static function checkServer ( \OCP\IConfig $config ) {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2014-03-14 16:03:18 +04:00
$errors = array ();
2014-09-08 16:56:11 +04:00
$CONFIG_DATADIRECTORY = $config -> getSystemValue ( 'datadirectory' , OC :: $SERVERROOT . '/data' );
2014-03-14 16:03:18 +04:00
2014-09-08 16:56:11 +04:00
if ( ! self :: needUpgrade ( $config ) && $config -> getSystemValue ( 'installed' , false )) {
2014-03-14 16:03:18 +04:00
// this check needs to be done every time
$errors = self :: checkDataDirectoryValidity ( $CONFIG_DATADIRECTORY );
}
2013-08-15 13:58:09 +04:00
// Assume that if checkServer() succeeded before in this session, then all is fine.
2014-07-16 21:40:22 +04:00
if ( \OC :: $server -> getSession () -> exists ( 'checkServer_succeeded' ) && \OC :: $server -> getSession () -> get ( 'checkServer_succeeded' )) {
2014-03-14 16:03:18 +04:00
return $errors ;
2013-08-15 10:49:19 +04:00
}
2013-08-15 13:58:09 +04:00
2013-08-15 10:49:19 +04:00
$webServerRestart = false ;
2015-07-30 01:04:30 +03:00
$setup = new \OC\Setup ( $config , \OC :: $server -> getIniWrapper (), \OC :: $server -> getL10N ( 'lib' ),
new \OC_Defaults (), \OC :: $server -> getLogger (), \OC :: $server -> getSecureRandom ());
2014-10-27 14:51:26 +03:00
$availableDatabases = $setup -> getSupportedDatabases ();
if ( empty ( $availableDatabases )) {
2013-08-15 10:49:19 +04:00
$errors [] = array (
2014-08-19 20:01:26 +04:00
'error' => $l -> t ( 'No database drivers (sqlite, mysql, or postgresql) installed.' ),
'hint' => '' //TODO: sane hint
2013-08-15 10:49:19 +04:00
);
$webServerRestart = true ;
2011-07-27 21:07:28 +04:00
}
2015-02-26 16:24:40 +03:00
// Check if server running on Windows platform
if ( OC_Util :: runningOnWindows ()) {
$errors [] = [
'error' => $l -> t ( 'Microsoft Windows Platform is not supported' ),
'hint' => $l -> t ( 'Running ownCloud Server on the Microsoft Windows platform is not supported. We suggest you ' .
'use a Linux server in a virtual machine if you have no option for migrating the server itself. ' .
'Find Linux packages as well as easy to deploy virtual machine images on <a href="%s">%s</a>. ' .
'For migrating existing installations to Linux you can find some tips and a migration script ' .
'in <a href="%s">our documentation</a>.' ,
[ 'https://owncloud.org/install/' , 'owncloud.org/install/' , 'https://owncloud.org/?p=8045' ])
];
}
2012-06-20 00:12:05 +04:00
// Check if config folder is writable.
2014-08-19 20:01:26 +04:00
if ( ! is_writable ( OC :: $configDir ) or ! is_readable ( OC :: $configDir )) {
2013-07-08 12:07:57 +04:00
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'Cannot write into "config" directory' ),
'hint' => $l -> t ( 'This can usually be fixed by '
2014-08-19 20:01:26 +04:00
. '%sgiving the webserver write access to the config directory%s.' ,
array ( '<a href="' . \OC_Helper :: linkToDocs ( 'admin-dir_permissions' ) . '" target="_blank">' , '</a>' ))
);
2012-06-20 00:12:05 +04:00
}
2012-06-21 23:35:34 +04:00
// Check if there is a writable install folder.
2014-09-08 16:56:11 +04:00
if ( $config -> getSystemValue ( 'appstoreenabled' , true )) {
2014-08-19 20:01:26 +04:00
if ( OC_App :: getInstallPath () === null
2013-02-11 20:44:02 +04:00
|| ! is_writable ( OC_App :: getInstallPath ())
2014-08-19 20:01:26 +04:00
|| ! is_readable ( OC_App :: getInstallPath ())
) {
2013-07-08 12:07:57 +04:00
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'Cannot write into "apps" directory' ),
'hint' => $l -> t ( 'This can usually be fixed by '
2014-08-19 20:01:26 +04:00
. '%sgiving the webserver write access to the apps directory%s'
. ' or disabling the appstore in the config file.' ,
array ( '<a href="' . \OC_Helper :: linkToDocs ( 'admin-dir_permissions' ) . '" target="_blank">' , '</a>' ))
);
2012-06-21 23:35:34 +04:00
}
2012-06-20 00:12:05 +04:00
}
// Create root dir.
2014-09-08 17:05:57 +04:00
if ( $config -> getSystemValue ( 'installed' , false )) {
if ( ! is_dir ( $CONFIG_DATADIRECTORY )) {
$success = @ mkdir ( $CONFIG_DATADIRECTORY );
if ( $success ) {
$errors = array_merge ( $errors , self :: checkDataDirectoryPermissions ( $CONFIG_DATADIRECTORY ));
} else {
$errors [] = array (
'error' => $l -> t ( 'Cannot create "data" directory (%s)' , array ( $CONFIG_DATADIRECTORY )),
'hint' => $l -> t ( 'This can usually be fixed by '
. '<a href="%s" target="_blank">giving the webserver write access to the root directory</a>.' ,
array ( OC_Helper :: linkToDocs ( 'admin-dir_permissions' )))
);
}
} else if ( ! is_writable ( $CONFIG_DATADIRECTORY ) or ! is_readable ( $CONFIG_DATADIRECTORY )) {
2015-02-12 13:20:38 +03:00
//common hint for all file permissions error messages
$permissionsHint = $l -> t ( 'Permissions can usually be fixed by '
. '%sgiving the webserver write access to the root directory%s.' ,
array ( '<a href="' . \OC_Helper :: linkToDocs ( 'admin-dir_permissions' ) . '" target="_blank">' , '</a>' ));
2013-07-08 12:07:57 +04:00
$errors [] = array (
2014-09-08 17:05:57 +04:00
'error' => 'Data directory (' . $CONFIG_DATADIRECTORY . ') not writable by ownCloud' ,
'hint' => $permissionsHint
2014-08-19 20:01:26 +04:00
);
2014-09-08 17:05:57 +04:00
} else {
$errors = array_merge ( $errors , self :: checkDataDirectoryPermissions ( $CONFIG_DATADIRECTORY ));
2012-06-20 00:12:05 +04:00
}
2011-07-27 21:07:28 +04:00
}
2013-08-15 10:49:19 +04:00
2014-08-19 20:01:26 +04:00
if ( ! OC_Util :: isSetLocaleWorking ()) {
2013-11-08 17:30:08 +04:00
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'Setting locale to %s failed' ,
2014-08-19 20:01:26 +04:00
array ( 'en_US.UTF-8/fr_FR.UTF-8/es_ES.UTF-8/de_DE.UTF-8/ru_RU.UTF-8/'
. 'pt_BR.UTF-8/it_IT.UTF-8/ja_JP.UTF-8/zh_CN.UTF-8' )),
2014-08-18 17:59:36 +04:00
'hint' => $l -> t ( 'Please install one of these locales on your system and restart your webserver.' )
2013-11-08 17:30:08 +04:00
);
}
2014-09-15 15:46:43 +04:00
// Contains the dependencies that should be checked against
// classes = class_exists
// functions = function_exists
// defined = defined
2015-02-21 14:12:34 +03:00
// ini = ini_get
2014-09-15 15:46:43 +04:00
// If the dependency is not found the missing module name is shown to the EndUser
2015-02-27 12:23:20 +03:00
// When adding new checks always verify that they pass on Travis as well
// for ini settings, see https://github.com/owncloud/administration/blob/master/travis-ci/custom.ini
2014-09-15 15:46:43 +04:00
$dependencies = array (
'classes' => array (
'ZipArchive' => 'zip' ,
'DOMDocument' => 'dom' ,
2014-11-20 15:13:14 +03:00
'XMLWriter' => 'XMLWriter'
2014-09-15 15:46:43 +04:00
),
2015-03-12 20:39:54 +03:00
'functions' => [
2014-09-15 15:46:43 +04:00
'xml_parser_create' => 'libxml' ,
'mb_detect_encoding' => 'mb multibyte' ,
'ctype_digit' => 'ctype' ,
'json_encode' => 'JSON' ,
'gd_info' => 'GD' ,
'gzencode' => 'zlib' ,
'iconv' => 'iconv' ,
2014-12-28 15:23:34 +03:00
'simplexml_load_string' => 'SimpleXML' ,
2015-03-12 20:39:54 +03:00
'hash' => 'HASH Message Digest Framework' ,
'curl_init' => 'cURL' ,
],
2014-09-15 15:46:43 +04:00
'defined' => array (
'PDO::ATTR_DRIVER_NAME' => 'PDO'
2015-02-21 14:12:34 +03:00
),
'ini' => [
2015-02-25 01:34:38 +03:00
'default_charset' => 'UTF-8' ,
2015-02-21 14:12:34 +03:00
],
2014-09-15 15:46:43 +04:00
);
$missingDependencies = array ();
2015-02-21 14:12:34 +03:00
$invalidIniSettings = [];
2014-05-29 03:21:54 +04:00
$moduleHint = $l -> t ( 'Please ask your server administrator to install the module.' );
2014-09-15 15:46:43 +04:00
2015-02-28 12:08:41 +03:00
/**
* FIXME : The dependency check does not work properly on HHVM on the moment
* and prevents installation . Once HHVM is more compatible with our
* approach to check for these values we should re - enable those
* checks .
*/
2015-05-04 17:14:12 +03:00
$iniWrapper = \OC :: $server -> getIniWrapper ();
2015-02-28 12:08:41 +03:00
if ( ! self :: runningOnHhvm ()) {
foreach ( $dependencies [ 'classes' ] as $class => $module ) {
if ( ! class_exists ( $class )) {
$missingDependencies [] = $module ;
}
2014-09-15 15:46:43 +04:00
}
2015-02-28 12:08:41 +03:00
foreach ( $dependencies [ 'functions' ] as $function => $module ) {
if ( ! function_exists ( $function )) {
$missingDependencies [] = $module ;
2015-02-21 14:12:34 +03:00
}
}
2015-02-28 12:08:41 +03:00
foreach ( $dependencies [ 'defined' ] as $defined => $module ) {
if ( ! defined ( $defined )) {
$missingDependencies [] = $module ;
2015-02-21 14:12:34 +03:00
}
}
2015-02-28 12:08:41 +03:00
foreach ( $dependencies [ 'ini' ] as $setting => $expected ) {
if ( is_bool ( $expected )) {
if ( $iniWrapper -> getBool ( $setting ) !== $expected ) {
$invalidIniSettings [] = [ $setting , $expected ];
}
}
if ( is_int ( $expected )) {
if ( $iniWrapper -> getNumeric ( $setting ) !== $expected ) {
$invalidIniSettings [] = [ $setting , $expected ];
}
}
if ( is_string ( $expected )) {
if ( strtolower ( $iniWrapper -> getString ( $setting )) !== strtolower ( $expected )) {
$invalidIniSettings [] = [ $setting , $expected ];
}
2015-02-25 01:34:38 +03:00
}
}
2015-02-21 14:12:34 +03:00
}
2014-09-15 15:46:43 +04:00
foreach ( $missingDependencies as $missingDependency ) {
2013-08-15 10:49:19 +04:00
$errors [] = array (
2014-09-15 15:46:43 +04:00
'error' => $l -> t ( 'PHP module %s not installed.' , array ( $missingDependency )),
2014-08-19 20:01:26 +04:00
'hint' => $moduleHint
2013-08-15 10:49:19 +04:00
);
$webServerRestart = true ;
2012-10-06 19:37:38 +04:00
}
2015-02-21 14:12:34 +03:00
foreach ( $invalidIniSettings as $setting ) {
2015-02-23 11:40:15 +03:00
if ( is_bool ( $setting [ 1 ])) {
$setting [ 1 ] = ( $setting [ 1 ]) ? 'on' : 'off' ;
}
2015-02-21 14:12:34 +03:00
$errors [] = [
2015-02-23 11:40:15 +03:00
'error' => $l -> t ( 'PHP setting "%s" is not set to "%s".' , [ $setting [ 0 ], var_export ( $setting [ 1 ], true )]),
2015-02-21 14:12:34 +03:00
'hint' => $l -> t ( 'Adjusting this setting in php.ini will make ownCloud run again' )
];
$webServerRestart = true ;
}
2014-09-15 15:46:43 +04:00
2015-05-04 17:14:12 +03:00
/**
* The mbstring . func_overload check can only be performed if the mbstring
* module is installed as it will return null if the checking setting is
* not available and thus a check on the boolean value fails .
*
* TODO : Should probably be implemented in the above generic dependency
* check somehow in the long - term .
*/
if ( $iniWrapper -> getBool ( 'mbstring.func_overload' ) !== null &&
$iniWrapper -> getBool ( 'mbstring.func_overload' ) === true ) {
$errors [] = array (
2015-05-19 22:15:22 +03:00
'error' => $l -> t ( 'mbstring.func_overload is set to "%s" instead of the expected value "0"' , [ $iniWrapper -> getString ( 'mbstring.func_overload' )]),
2015-05-04 17:14:12 +03:00
'hint' => $l -> t ( 'To fix this issue set <code>mbstring.func_overload</code> to <code>0</code> in your php.ini' )
);
}
2014-05-19 23:51:35 +04:00
if ( ! self :: isAnnotationsWorking ()) {
$errors [] = array (
2015-05-19 22:15:22 +03:00
'error' => $l -> t ( 'PHP is apparently set up to strip inline doc blocks. This will make several core apps inaccessible.' ),
2015-01-22 16:52:47 +03:00
'hint' => $l -> t ( 'This is probably caused by a cache/accelerator such as Zend OPcache or eAccelerator.' )
2014-05-19 23:51:35 +04:00
);
}
2012-09-12 01:51:12 +04:00
2015-03-11 00:59:23 +03:00
if ( ! \OC :: $CLI && $webServerRestart ) {
2013-08-15 10:49:19 +04:00
$errors [] = array (
2014-08-19 20:01:26 +04:00
'error' => $l -> t ( 'PHP modules have been installed, but they are still listed as missing?' ),
'hint' => $l -> t ( 'Please ask your server administrator to restart the web server.' )
2013-08-15 10:49:19 +04:00
);
2012-06-01 22:00:33 +04:00
}
2011-07-27 21:07:28 +04:00
2014-03-15 16:28:20 +04:00
$errors = array_merge ( $errors , self :: checkDatabaseVersion ());
2013-08-15 13:58:09 +04:00
// Cache the result of this function
2014-07-16 21:40:22 +04:00
\OC :: $server -> getSession () -> set ( 'checkServer_succeeded' , count ( $errors ) == 0 );
2013-08-15 13:58:09 +04:00
2011-07-27 21:07:28 +04:00
return $errors ;
}
2011-09-18 23:31:56 +04:00
2014-03-15 16:28:20 +04:00
/**
* Check the database version
2014-08-19 20:01:26 +04:00
*
2014-03-15 16:28:20 +04:00
* @ return array errors array
*/
public static function checkDatabaseVersion () {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2014-03-15 16:28:20 +04:00
$errors = array ();
$dbType = \OC_Config :: getValue ( 'dbtype' , 'sqlite' );
if ( $dbType === 'pgsql' ) {
// check PostgreSQL version
try {
$result = \OC_DB :: executeAudited ( 'SHOW SERVER_VERSION' );
$data = $result -> fetchRow ();
if ( isset ( $data [ 'server_version' ])) {
$version = $data [ 'server_version' ];
if ( version_compare ( $version , '9.0.0' , '<' )) {
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'PostgreSQL >= 9 required' ),
'hint' => $l -> t ( 'Please upgrade your database version' )
2014-03-15 16:28:20 +04:00
);
}
}
2014-03-26 02:17:00 +04:00
} catch ( \Doctrine\DBAL\DBALException $e ) {
2014-03-24 14:54:44 +04:00
\OCP\Util :: logException ( 'core' , $e );
2014-03-15 16:28:20 +04:00
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'Error occurred while checking PostgreSQL version' ),
'hint' => $l -> t ( 'Please make sure you have PostgreSQL >= 9 or'
2014-08-19 20:01:26 +04:00
. ' check the logs for more information about the error' )
2014-03-15 16:28:20 +04:00
);
}
}
return $errors ;
}
2013-01-19 08:30:56 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check for correct file permissions of data directory
2014-08-19 20:01:26 +04:00
*
2014-02-06 19:30:58 +04:00
* @ param string $dataDirectory
2013-08-23 09:30:42 +04:00
* @ return array arrays with error messages and hints
*/
2013-01-19 08:30:56 +04:00
public static function checkDataDirectoryPermissions ( $dataDirectory ) {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2013-01-19 08:30:56 +04:00
$errors = array ();
2013-08-23 09:30:42 +04:00
if ( self :: runningOnWindows ()) {
2013-01-19 08:30:56 +04:00
//TODO: permissions checks for windows hosts
} else {
2014-05-29 03:21:54 +04:00
$permissionsModHint = $l -> t ( 'Please change the permissions to 0770 so that the directory'
2014-08-19 20:01:26 +04:00
. ' cannot be listed by other users.' );
2013-08-15 10:49:19 +04:00
$perms = substr ( decoct ( @ fileperms ( $dataDirectory )), - 3 );
if ( substr ( $perms , - 1 ) != '0' ) {
2014-03-17 15:53:26 +04:00
chmod ( $dataDirectory , 0770 );
2013-01-19 08:30:56 +04:00
clearstatcache ();
2013-08-15 10:49:19 +04:00
$perms = substr ( decoct ( @ fileperms ( $dataDirectory )), - 3 );
if ( substr ( $perms , 2 , 1 ) != '0' ) {
$errors [] = array (
2014-05-29 03:21:54 +04:00
'error' => $l -> t ( 'Data directory (%s) is readable by other users' , array ( $dataDirectory )),
2013-08-15 10:49:19 +04:00
'hint' => $permissionsModHint
);
2013-01-19 08:30:56 +04:00
}
}
}
return $errors ;
}
2014-03-14 16:03:18 +04:00
/**
* Check that the data directory exists and is valid by
* checking the existence of the " .ocdata " file .
*
* @ param string $dataDirectory data directory path
2015-03-28 02:27:21 +03:00
* @ return array errors found
2014-03-14 16:03:18 +04:00
*/
public static function checkDataDirectoryValidity ( $dataDirectory ) {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2015-03-28 02:27:21 +03:00
$errors = [];
if ( ! self :: runningOnWindows () && $dataDirectory [ 0 ] !== '/' ) {
$errors [] = [
'error' => $l -> t ( 'Data directory (%s) must be an absolute path' , [ $dataDirectory ]),
'hint' => $l -> t ( 'Check the value of "datadirectory" in your configuration' )
];
}
2014-08-19 20:01:26 +04:00
if ( ! file_exists ( $dataDirectory . '/.ocdata' )) {
2015-03-28 02:27:21 +03:00
$errors [] = [
'error' => $l -> t ( 'Data directory (%s) is invalid' , [ $dataDirectory ]),
2014-05-29 03:21:54 +04:00
'hint' => $l -> t ( 'Please check that the data directory contains a file' .
' ".ocdata" in its root.' )
2015-03-28 02:27:21 +03:00
];
2014-03-14 16:03:18 +04:00
}
return $errors ;
}
2013-08-15 10:49:19 +04:00
/**
2014-04-21 17:44:54 +04:00
* @ param array $errors
2015-01-22 16:13:02 +03:00
* @ param string [] $messages
2013-08-15 10:49:19 +04:00
*/
2015-01-22 16:13:02 +03:00
public static function displayLoginPage ( $errors = array (), $messages = []) {
2012-08-09 20:27:59 +04:00
$parameters = array ();
2014-08-19 20:01:26 +04:00
foreach ( $errors as $value ) {
2012-10-12 18:12:43 +04:00
$parameters [ $value ] = true ;
}
2015-01-22 16:13:02 +03:00
$parameters [ 'messages' ] = $messages ;
2014-09-08 23:44:13 +04:00
if ( ! empty ( $_REQUEST [ 'user' ])) {
$parameters [ " username " ] = $_REQUEST [ 'user' ];
2012-08-09 20:27:59 +04:00
$parameters [ 'user_autofocus' ] = false ;
2011-10-01 01:48:20 +04:00
} else {
$parameters [ " username " ] = '' ;
2012-08-09 20:27:59 +04:00
$parameters [ 'user_autofocus' ] = true ;
2011-09-26 00:47:29 +04:00
}
2012-08-09 20:27:59 +04:00
if ( isset ( $_REQUEST [ 'redirect_url' ])) {
2015-02-02 17:09:59 +03:00
$parameters [ 'redirect_url' ] = $_REQUEST [ 'redirect_url' ];
2013-01-03 02:02:38 +04:00
}
2013-01-29 20:28:08 +04:00
$parameters [ 'alt_login' ] = OC_App :: getAlternativeLogIns ();
2013-09-24 20:01:34 +04:00
$parameters [ 'rememberLoginAllowed' ] = self :: rememberLoginAllowed ();
2011-09-26 00:47:29 +04:00
OC_Template :: printGuestPage ( " " , " login " , $parameters );
}
2011-09-28 13:44:46 +04:00
2011-10-01 01:05:10 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check if the app is enabled , redirects to home if not
2014-08-19 20:01:26 +04:00
*
2014-02-19 12:31:54 +04:00
* @ param string $app
2013-08-15 10:49:19 +04:00
* @ return void
2013-01-03 02:02:38 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function checkAppEnabled ( $app ) {
2014-08-19 20:01:26 +04:00
if ( ! OC_App :: isEnabled ( $app )) {
header ( 'Location: ' . OC_Helper :: linkToAbsolute ( '' , 'index.php' ));
2011-10-01 01:05:10 +04:00
exit ();
}
}
2011-09-18 23:31:56 +04:00
/**
2013-01-03 02:02:38 +04:00
* Check if the user is logged in , redirects to home if not . With
* redirect URL parameter to the request URI .
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return void
2013-01-03 02:02:38 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function checkLoggedIn () {
2011-09-18 23:31:56 +04:00
// Check if we are a user
2014-08-19 20:01:26 +04:00
if ( ! OC_User :: isLoggedIn ()) {
header ( 'Location: ' . OC_Helper :: linkToAbsolute ( '' , 'index.php' ,
2015-02-10 15:02:48 +03:00
[
'redirect_url' => \OC :: $server -> getRequest () -> getRequestUri ()
]
)
);
2011-09-18 23:31:56 +04:00
exit ();
}
}
/**
2014-05-19 19:50:53 +04:00
* Check if the user is a admin , redirects to home if not
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return void
2013-01-03 02:02:38 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function checkAdminUser () {
2013-10-31 01:59:31 +04:00
OC_Util :: checkLoggedIn ();
2014-08-19 20:01:26 +04:00
if ( ! OC_User :: isAdminUser ( OC_User :: getUser ())) {
header ( 'Location: ' . OC_Helper :: linkToAbsolute ( '' , 'index.php' ));
2011-09-18 23:31:56 +04:00
exit ();
}
}
2012-07-09 23:51:19 +04:00
/**
2013-09-24 20:01:34 +04:00
* Check if it is allowed to remember login .
2013-09-26 21:34:28 +04:00
*
* @ note Every app can set 'rememberlogin' to 'false' to disable the remember login feature
2013-09-24 20:01:34 +04:00
*
* @ return bool
*/
public static function rememberLoginAllowed () {
2013-09-26 21:34:28 +04:00
$apps = OC_App :: getEnabledApps ();
foreach ( $apps as $app ) {
$appInfo = OC_App :: getAppInfo ( $app );
if ( isset ( $appInfo [ 'rememberlogin' ]) && $appInfo [ 'rememberlogin' ] === 'false' ) {
return false ;
}
}
return true ;
2013-09-24 20:01:34 +04:00
}
2012-07-09 23:51:19 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check if the user is a subadmin , redirects to home if not
2014-08-19 20:01:26 +04:00
*
2014-02-06 19:30:58 +04:00
* @ return null | boolean $groups where the current user is subadmin
2013-01-03 02:02:38 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function checkSubAdminUser () {
2013-10-31 01:59:31 +04:00
OC_Util :: checkLoggedIn ();
2014-08-19 20:01:26 +04:00
if ( ! OC_SubAdmin :: isSubAdmin ( OC_User :: getUser ())) {
header ( 'Location: ' . OC_Helper :: linkToAbsolute ( '' , 'index.php' ));
2012-07-09 23:51:19 +04:00
exit ();
}
2012-07-15 18:31:28 +04:00
return true ;
2012-07-09 23:51:19 +04:00
}
2011-09-18 23:31:56 +04:00
/**
2014-07-01 18:02:38 +04:00
* Returns the URL of the default page
* based on the system configuration and
* the apps visible for the current user
*
* @ return string URL
2013-01-03 02:02:38 +04:00
*/
2014-07-01 18:02:38 +04:00
public static function getDefaultPageUrl () {
2014-03-28 21:05:48 +04:00
$urlGenerator = \OC :: $server -> getURLGenerator ();
2014-09-29 19:07:43 +04:00
// Deny the redirect if the URL contains a @
// This prevents unvalidated redirects like ?redirect_url=:user@domain.com
if ( isset ( $_REQUEST [ 'redirect_url' ]) && strpos ( $_REQUEST [ 'redirect_url' ], '@' ) === false ) {
$location = $urlGenerator -> getAbsoluteURL ( urldecode ( $_REQUEST [ 'redirect_url' ]));
2013-08-15 10:49:19 +04:00
} else {
2015-07-03 15:16:29 +03:00
$defaultPage = \OC :: $server -> getAppConfig () -> getValue ( 'core' , 'defaultpage' );
2013-08-15 10:49:19 +04:00
if ( $defaultPage ) {
2014-03-28 21:05:48 +04:00
$location = $urlGenerator -> getAbsoluteURL ( $defaultPage );
2013-08-15 10:49:19 +04:00
} else {
2014-07-01 17:42:26 +04:00
$appId = 'files' ;
$defaultApps = explode ( ',' , \OCP\Config :: getSystemValue ( 'defaultapp' , 'files' ));
// find the first app that is enabled for the current user
foreach ( $defaultApps as $defaultApp ) {
$defaultApp = OC_App :: cleanAppId ( strip_tags ( $defaultApp ));
2015-02-18 16:24:50 +03:00
if ( static :: getAppManager () -> isEnabledForUser ( $defaultApp )) {
2014-07-01 17:42:26 +04:00
$appId = $defaultApp ;
break ;
}
}
2014-07-01 18:02:38 +04:00
$location = $urlGenerator -> getAbsoluteURL ( '/index.php/apps/' . $appId . '/' );
2012-08-06 20:49:06 +04:00
}
2011-10-04 21:27:57 +04:00
}
2014-07-01 18:02:38 +04:00
return $location ;
}
/**
* Redirect to the user default page
2014-08-19 20:01:26 +04:00
*
2014-07-01 18:02:38 +04:00
* @ return void
*/
public static function redirectToDefaultPage () {
$location = self :: getDefaultPageUrl ();
2014-08-19 20:01:26 +04:00
header ( 'Location: ' . $location );
2011-09-18 23:31:56 +04:00
exit ();
}
2012-06-05 21:32:48 +04:00
2013-08-15 10:49:19 +04:00
/**
2014-05-19 19:50:53 +04:00
* get an id unique for this instance
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return string
*/
public static function getInstanceId () {
$id = OC_Config :: getValue ( 'instanceid' , null );
2014-08-19 20:01:26 +04:00
if ( is_null ( $id )) {
2013-08-15 10:49:19 +04:00
// We need to guarantee at least one letter in instanceid so it can be used as the session_name
2014-09-22 23:24:33 +04:00
$id = 'oc' . \OC :: $server -> getSecureRandom () -> getLowStrengthGenerator () -> generate ( 10 , \OCP\Security\ISecureRandom :: CHAR_LOWER . \OCP\Security\ISecureRandom :: CHAR_DIGITS );
2013-09-18 13:07:19 +04:00
OC_Config :: $object -> setValue ( 'instanceid' , $id );
2013-08-15 10:49:19 +04:00
}
return $id ;
}
2012-06-09 17:05:14 +04:00
2015-09-08 22:28:15 +03:00
protected static $encryptedToken ;
2012-09-28 15:30:44 +04:00
/**
2014-05-19 19:50:53 +04:00
* Register an get / post call . Important to prevent CSRF attacks .
2014-08-19 20:01:26 +04:00
*
2015-08-13 08:36:42 +03:00
* @ return string The encrypted CSRF token , the shared secret is appended after the `:` .
*
2012-09-28 15:30:44 +04:00
* @ description
* Creates a 'request token' ( random ) and stores it inside the session .
* Ever subsequent ( ajax ) request must use such a valid token to succeed ,
* otherwise the request will be denied as a protection against CSRF .
* @ see OC_Util :: isCallRegistered ()
2012-06-09 17:05:14 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function callRegister () {
2015-09-08 22:28:15 +03:00
// Use existing token if function has already been called
if ( isset ( self :: $encryptedToken )) {
return self :: $encryptedToken ;
}
2012-10-28 23:50:50 +04:00
// Check if a token exists
2014-07-16 21:40:22 +04:00
if ( ! \OC :: $server -> getSession () -> exists ( 'requesttoken' )) {
2012-10-28 23:50:50 +04:00
// No valid token found, generate a new one.
2014-09-03 19:46:48 +04:00
$requestToken = \OC :: $server -> getSecureRandom () -> getMediumStrengthGenerator () -> generate ( 30 );
2014-07-16 21:40:22 +04:00
\OC :: $server -> getSession () -> set ( 'requesttoken' , $requestToken );
2012-10-28 23:50:50 +04:00
} else {
// Valid token already exists, send it
2014-07-16 21:40:22 +04:00
$requestToken = \OC :: $server -> getSession () -> get ( 'requesttoken' );
2012-06-11 14:13:08 +04:00
}
2015-08-13 08:36:42 +03:00
// Encrypt the token to mitigate breach-like attacks
$sharedSecret = \OC :: $server -> getSecureRandom () -> getMediumStrengthGenerator () -> generate ( 10 );
2015-09-08 22:28:15 +03:00
self :: $encryptedToken = \OC :: $server -> getCrypto () -> encrypt ( $requestToken , $sharedSecret ) . ':' . $sharedSecret ;
return self :: $encryptedToken ;
2012-06-09 17:05:14 +04:00
}
/**
2014-05-19 19:50:53 +04:00
* Check an ajax get / post call if the request token is valid .
2014-08-19 20:01:26 +04:00
*
2012-06-13 19:33:19 +04:00
* @ return boolean False if request token is not set or is invalid .
2012-10-28 21:24:11 +04:00
* @ see OC_Util :: callRegister ()
2012-06-09 17:05:14 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function isCallRegistered () {
2013-09-27 17:16:34 +04:00
return \OC :: $server -> getRequest () -> passesCSRFCheck ();
2012-06-09 17:05:14 +04:00
}
2012-06-13 19:33:19 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check an ajax get / post call if the request token is valid . Exit if not .
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return void
2012-06-13 19:33:19 +04:00
*/
2012-09-07 17:22:01 +04:00
public static function callCheck () {
2014-08-19 20:01:26 +04:00
if ( ! OC_Util :: isCallRegistered ()) {
2013-08-15 10:49:19 +04:00
exit ();
2012-06-13 19:33:19 +04:00
}
}
2012-08-29 10:38:33 +04:00
2012-06-21 16:07:04 +04:00
/**
2014-05-19 19:50:53 +04:00
* Public function to sanitize HTML
2012-06-21 16:07:04 +04:00
*
2012-06-22 10:17:35 +04:00
* This function is used to sanitize HTML and should be applied on any
* string or array of strings before displaying it on a web page .
2012-08-29 10:38:33 +04:00
*
2014-05-12 00:51:30 +04:00
* @ param string | array & $value
* @ return string | array an array of sanitized strings or a single sanitized string , depends on the input parameter .
2012-06-19 19:20:19 +04:00
*/
2014-08-19 20:01:26 +04:00
public static function sanitizeHTML ( & $value ) {
2013-02-22 03:51:54 +04:00
if ( is_array ( $value )) {
2013-01-15 01:01:52 +04:00
array_walk_recursive ( $value , 'OC_Util::sanitizeHTML' );
} else {
2013-08-22 03:20:28 +04:00
//Specify encoding for PHP<5.4
2014-04-11 21:42:15 +04:00
$value = htmlspecialchars (( string ) $value , ENT_QUOTES , 'UTF-8' );
2013-01-15 01:01:52 +04:00
}
2012-06-19 19:20:19 +04:00
return $value ;
}
2013-09-27 15:34:48 +04:00
2013-07-04 20:21:49 +04:00
/**
2014-05-19 19:50:53 +04:00
* Public function to encode url parameters
2013-07-04 20:21:49 +04:00
*
* This function is used to encode path to file before output .
* Encoding is done according to RFC 3986 with one exception :
2013-09-27 15:34:48 +04:00
* Character '/' is preserved as is .
2013-07-04 20:21:49 +04:00
*
* @ param string $component part of URI to encode
2013-09-27 15:34:48 +04:00
* @ return string
2013-07-04 20:21:49 +04:00
*/
public static function encodePath ( $component ) {
$encoded = rawurlencode ( $component );
$encoded = str_replace ( '%2F' , '/' , $encoded );
return $encoded ;
}
2012-06-21 16:07:04 +04:00
2012-07-24 02:39:59 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check if the . htaccess file is working
2015-03-26 16:51:33 +03:00
* @ param \OCP\IConfig $config
2013-08-15 10:49:19 +04:00
* @ return bool
2015-03-26 16:51:33 +03:00
* @ throws Exception
* @ throws \OC\HintException If the test file can ' t get written .
2012-07-24 02:39:59 +04:00
*/
2015-03-26 16:51:33 +03:00
public function isHtaccessWorking ( \OCP\IConfig $config ) {
2015-08-06 17:51:31 +03:00
2015-03-26 16:51:33 +03:00
if ( \OC :: $CLI || ! $config -> getSystemValue ( 'check_for_working_htaccess' , true )) {
2013-10-17 18:27:43 +04:00
return true ;
}
2014-04-29 17:00:57 +04:00
2015-01-08 11:13:18 +03:00
// php dev server does not support htaccess
if ( php_sapi_name () === 'cli-server' ) {
return false ;
}
2012-06-21 16:07:04 +04:00
// testdata
2013-08-18 12:33:09 +04:00
$fileName = '/htaccesstest.txt' ;
$testContent = 'testcontent' ;
2012-06-21 16:07:04 +04:00
// creating a test file
2015-03-26 16:51:33 +03:00
$testFile = $config -> getSystemValue ( 'datadirectory' , OC :: $SERVERROOT . '/data' ) . '/' . $fileName ;
2012-10-26 20:17:43 +04:00
2014-08-19 20:01:26 +04:00
if ( file_exists ( $testFile )) { // already running this test, possible recursive call
2012-10-26 20:17:43 +04:00
return false ;
}
2013-09-11 00:05:20 +04:00
$fp = @ fopen ( $testFile , 'w' );
if ( ! $fp ) {
throw new OC\HintException ( 'Can\'t create test file to check for working .htaccess file.' ,
2014-08-19 20:01:26 +04:00
'Make sure it is possible for the webserver to write to ' . $testFile );
2013-09-11 00:05:20 +04:00
}
fwrite ( $fp , $testContent );
fclose ( $fp );
2012-06-21 16:07:04 +04:00
// accessing the file via http
2014-08-19 20:01:26 +04:00
$url = OC_Helper :: makeURLAbsolute ( OC :: $WEBROOT . '/data' . $fileName );
$content = self :: getUrlContent ( $url );
2012-06-21 16:07:04 +04:00
// cleanup
2013-09-11 00:05:20 +04:00
@ unlink ( $testFile );
2012-06-21 16:07:04 +04:00
2014-08-19 20:01:26 +04:00
/*
* If the content is not equal to test content our . htaccess
* is working as required
*/
return $content !== $testContent ;
2012-07-24 02:39:59 +04:00
}
2012-06-21 16:07:04 +04:00
2013-01-03 02:02:38 +04:00
/**
2013-08-22 03:20:28 +04:00
* Check if the setlocal call does not work . This can happen if the right
2013-02-11 20:44:02 +04:00
* local packages are not available on the server .
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return bool
2013-01-03 02:02:38 +04:00
*/
2013-08-18 12:33:09 +04:00
public static function isSetLocaleWorking () {
2013-02-05 18:46:55 +04:00
// setlocale test is pointless on Windows
2014-08-19 20:01:26 +04:00
if ( OC_Util :: runningOnWindows ()) {
2013-02-05 18:46:55 +04:00
return true ;
}
2013-11-15 16:06:35 +04:00
\Patchwork\Utf8\Bootup :: initLocale ();
if ( '' === basename ( '§' )) {
2013-02-08 20:49:54 +04:00
return false ;
2013-04-05 22:49:57 +04:00
}
return true ;
2012-12-19 18:10:33 +04:00
}
2014-03-07 05:53:33 +04:00
/**
* Check if it ' s possible to get the inline annotations
*
* @ return bool
*/
public static function isAnnotationsWorking () {
$reflection = new \ReflectionMethod ( __METHOD__ );
$docs = $reflection -> getDocComment ();
return ( is_string ( $docs ) && strlen ( $docs ) > 50 );
}
2013-02-04 18:04:26 +04:00
/**
2014-05-19 19:50:53 +04:00
* Check if the PHP module fileinfo is loaded .
2014-08-19 20:01:26 +04:00
*
2013-02-04 18:04:26 +04:00
* @ return bool
*/
public static function fileInfoLoaded () {
return function_exists ( 'finfo_open' );
}
2012-11-29 20:58:24 +04:00
/**
2014-05-19 19:50:53 +04:00
* clear all levels of output buffering
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return void
2012-11-29 20:58:24 +04:00
*/
2014-08-19 20:01:26 +04:00
public static function obEnd () {
2012-11-29 20:58:24 +04:00
while ( ob_get_level ()) {
ob_end_clean ();
}
}
2012-11-08 21:08:44 +04:00
2012-10-15 16:25:40 +04:00
/**
2014-05-19 19:50:53 +04:00
* Generates a cryptographic secure pseudo - random string
2014-08-19 20:01:26 +04:00
*
2014-05-12 00:51:30 +04:00
* @ param int $length of the random string
* @ return string
2014-08-26 21:02:40 +04:00
* @ deprecated Use \OC :: $server -> getSecureRandom () -> getMediumStrengthGenerator () -> generate ( $length ); instead
2013-01-03 02:02:38 +04:00
*/
2013-08-15 10:49:19 +04:00
public static function generateRandomBytes ( $length = 30 ) {
2014-09-03 19:18:00 +04:00
return \OC :: $server -> getSecureRandom () -> getMediumStrengthGenerator () -> generate ( $length , \OCP\Security\ISecureRandom :: CHAR_LOWER . \OCP\Security\ISecureRandom :: CHAR_DIGITS );
2012-09-29 18:44:02 +04:00
}
2012-10-14 23:04:08 +04:00
2013-01-03 02:02:38 +04:00
/**
2014-09-11 21:21:56 +04:00
* Get URL content
2013-01-03 02:02:38 +04:00
* @ param string $url Url to get content
2014-09-11 21:21:56 +04:00
* @ deprecated Use \OC :: $server -> getHTTPHelper () -> getUrlContent ( $url );
2014-07-27 18:46:32 +04:00
* @ throws Exception If the URL does not start with http :// or https ://
2013-01-03 02:02:38 +04:00
* @ return string of the response or false on error
* This function get the content of a page via curl , if curl is enabled .
2013-09-26 20:41:19 +04:00
* If not , file_get_contents is used .
2015-04-08 14:50:34 +03:00
* @ deprecated Use \OCP\Http\Client\IClientService
2013-01-03 02:02:38 +04:00
*/
2013-09-26 20:41:19 +04:00
public static function getUrlContent ( $url ) {
2014-09-11 21:21:56 +04:00
try {
return \OC :: $server -> getHTTPHelper () -> getUrlContent ( $url );
} catch ( \Exception $e ) {
throw $e ;
2013-01-03 02:02:38 +04:00
}
2012-12-15 02:04:42 +04:00
}
2013-01-03 02:02:38 +04:00
2013-02-05 18:43:12 +04:00
/**
2014-03-20 15:31:36 +04:00
* Checks whether the server is running on Windows
2014-08-19 20:01:26 +04:00
*
2014-03-20 15:31:36 +04:00
* @ return bool true if running on Windows , false otherwise
2013-02-05 18:43:12 +04:00
*/
public static function runningOnWindows () {
return ( substr ( PHP_OS , 0 , 3 ) === " WIN " );
}
2014-03-20 15:31:36 +04:00
/**
* Checks whether the server is running on Mac OS X
2014-08-19 20:01:26 +04:00
*
2014-03-20 15:31:36 +04:00
* @ return bool true if running on Mac OS X , false otherwise
*/
public static function runningOnMac () {
return ( strtoupper ( substr ( PHP_OS , 0 , 6 )) === 'DARWIN' );
}
2015-01-23 15:52:42 +03:00
/**
* Checks whether server is running on HHVM
*
* @ return bool True if running on HHVM , false otherwise
*/
public static function runningOnHhvm () {
return defined ( 'HHVM_VERSION' );
}
2013-04-24 15:45:40 +04:00
/**
* Handles the case that there may not be a theme , then check if a " default "
* theme exists and take that one
2014-08-19 20:01:26 +04:00
*
2013-04-24 15:45:40 +04:00
* @ return string the theme
*/
public static function getTheme () {
2013-06-19 13:58:29 +04:00
$theme = OC_Config :: getValue ( " theme " , '' );
2013-04-24 15:45:40 +04:00
2014-08-19 20:01:26 +04:00
if ( $theme === '' ) {
if ( is_dir ( OC :: $SERVERROOT . '/themes/default' )) {
2013-04-24 15:45:40 +04:00
$theme = 'default' ;
}
}
return $theme ;
}
2014-09-13 10:33:18 +04:00
/**
* Clear a single file from the opcode cache
* This is useful for writing to the config file
* in case the opcode cache does not re - validate files
* Returns true if successful , false if unsuccessful :
* caller should fall back on clearing the entire cache
* with clearOpcodeCache () if unsuccessful
*
2014-11-07 05:05:20 +03:00
* @ param string $path the path of the file to clear from the cache
2014-09-13 10:33:18 +04:00
* @ return bool true if underlying function returns true , otherwise false
*/
2014-11-07 05:05:20 +03:00
public static function deleteFromOpcodeCache ( $path ) {
2014-09-13 10:33:18 +04:00
$ret = false ;
if ( $path ) {
// APC >= 3.1.1
if ( function_exists ( 'apc_delete_file' )) {
$ret = @ apc_delete_file ( $path );
}
// Zend OpCache >= 7.0.0, PHP >= 5.5.0
if ( function_exists ( 'opcache_invalidate' )) {
$ret = opcache_invalidate ( $path );
}
}
return $ret ;
}
2013-05-25 19:25:43 +04:00
/**
2014-05-19 19:50:53 +04:00
* Clear the opcode cache if one exists
2013-05-25 19:25:43 +04:00
* This is necessary for writing to the config file
2013-08-22 03:20:28 +04:00
* in case the opcode cache does not re - validate files
2014-08-19 20:01:26 +04:00
*
2013-08-15 10:49:19 +04:00
* @ return void
2013-05-25 19:25:43 +04:00
*/
public static function clearOpcodeCache () {
// APC
if ( function_exists ( 'apc_clear_cache' )) {
apc_clear_cache ();
}
// Zend Opcache
if ( function_exists ( 'accelerator_reset' )) {
accelerator_reset ();
}
// XCache
if ( function_exists ( 'xcache_clear_cache' )) {
2013-12-14 21:32:48 +04:00
if ( ini_get ( 'xcache.admin.enable_auth' )) {
2015-07-03 15:06:40 +03:00
\OCP\Util :: writeLog ( 'core' , 'XCache opcode cache will not be cleared because "xcache.admin.enable_auth" is enabled.' , \OCP\Util :: WARN );
2013-12-14 21:32:48 +04:00
} else {
2015-05-12 20:22:39 +03:00
@ xcache_clear_cache ( XC_TYPE_PHP , 0 );
2013-12-14 21:32:48 +04:00
}
2013-05-25 19:25:43 +04:00
}
2013-07-28 18:33:03 +04:00
// Opcache (PHP >= 5.5)
if ( function_exists ( 'opcache_reset' )) {
opcache_reset ();
}
2013-05-25 19:25:43 +04:00
}
2013-04-24 15:45:40 +04:00
2013-05-24 22:35:01 +04:00
/**
* Normalize a unicode string
2014-08-19 20:01:26 +04:00
*
2013-05-24 22:35:01 +04:00
* @ param string $value a not normalized string
* @ return bool | string
*/
public static function normalizeUnicode ( $value ) {
2015-01-10 01:34:26 +03:00
if ( Normalizer :: isNormalized ( $value )) {
return $value ;
}
$normalizedValue = Normalizer :: normalize ( $value );
2014-09-09 16:41:45 +04:00
if ( $normalizedValue === null || $normalizedValue === false ) {
2015-01-10 01:34:26 +03:00
\OC :: $server -> getLogger () -> warning ( 'normalizing failed for "' . $value . '"' , [ 'app' => 'core' ]);
return $value ;
2013-05-24 22:35:01 +04:00
}
2013-04-24 15:45:40 +04:00
2015-01-10 01:34:26 +03:00
return $normalizedValue ;
2013-05-24 22:35:01 +04:00
}
2013-07-29 20:24:05 +04:00
2013-08-15 10:49:19 +04:00
/**
2014-02-06 19:30:58 +04:00
* @ param boolean | string $file
2013-08-15 10:49:19 +04:00
* @ return string
*/
public static function basename ( $file ) {
2013-07-30 01:32:03 +04:00
$file = rtrim ( $file , '/' );
2013-07-29 20:24:05 +04:00
$t = explode ( '/' , $file );
return array_pop ( $t );
}
2013-11-25 00:26:34 +04:00
/**
* A human readable string is generated based on version , channel and build number
2014-08-19 20:01:26 +04:00
*
2013-11-25 00:26:34 +04:00
* @ return string
*/
public static function getHumanVersion () {
2014-08-19 20:01:26 +04:00
$version = OC_Util :: getVersionString () . ' (' . OC_Util :: getChannel () . ')' ;
2013-11-25 00:26:34 +04:00
$build = OC_Util :: getBuild ();
2014-08-19 20:01:26 +04:00
if ( ! empty ( $build ) and OC_Util :: getChannel () === 'daily' ) {
2013-11-25 00:26:34 +04:00
$version .= ' Build:' . $build ;
}
return $version ;
}
2014-01-10 19:14:37 +04:00
/**
* Returns whether the given file name is valid
2014-08-19 20:01:26 +04:00
*
2014-05-12 00:51:30 +04:00
* @ param string $file file name to check
2014-01-10 19:14:37 +04:00
* @ return bool true if the file name is valid , false otherwise
2015-02-18 20:35:27 +03:00
* @ deprecated use \OC\Files\View :: verifyPath ()
2014-01-10 19:14:37 +04:00
*/
public static function isValidFileName ( $file ) {
$trimmed = trim ( $file );
if ( $trimmed === '' ) {
return false ;
}
2015-09-21 15:09:28 +03:00
if ( \OC\Files\Filesystem :: isIgnoredDir ( $trimmed )) {
2014-01-10 19:14:37 +04:00
return false ;
}
foreach ( str_split ( $trimmed ) as $char ) {
2014-11-25 18:28:41 +03:00
if ( strpos ( \OCP\Constants :: FILENAME_INVALID_CHARS , $char ) !== false ) {
2014-01-10 19:14:37 +04:00
return false ;
}
}
return true ;
}
2014-06-10 20:01:07 +04:00
/**
2014-09-02 16:30:46 +04:00
* Check whether the instance needs to perform an upgrade ,
* either when the core version is higher or any app requires
* an upgrade .
2014-06-10 20:01:07 +04:00
*
2014-09-08 16:56:11 +04:00
* @ param \OCP\IConfig $config
2014-09-02 16:30:46 +04:00
* @ return bool whether the core or any app needs an upgrade
2014-06-10 20:01:07 +04:00
*/
2014-10-24 16:13:40 +04:00
public static function needUpgrade ( \OCP\IConfig $config ) {
2014-09-08 16:56:11 +04:00
if ( $config -> getSystemValue ( 'installed' , false )) {
$installedVersion = $config -> getSystemValue ( 'version' , '0.0.0' );
2014-06-10 20:01:07 +04:00
$currentVersion = implode ( '.' , OC_Util :: getVersion ());
2015-08-30 19:03:33 +03:00
$versionDiff = version_compare ( $currentVersion , $installedVersion );
if ( $versionDiff > 0 ) {
2014-07-24 19:15:38 +04:00
return true ;
2015-08-30 19:03:33 +03:00
} else if ( $versionDiff < 0 ) {
// downgrade attempt, throw exception
throw new \OC\HintException ( 'Downgrading is not supported and is likely to cause unpredictable issues (from ' . $installedVersion . ' to ' . $currentVersion . ')' );
2014-07-24 19:15:38 +04:00
}
2014-09-02 16:30:46 +04:00
// also check for upgrades for apps (independently from the user)
$apps = \OC_App :: getEnabledApps ( false , true );
$shouldUpgrade = false ;
2014-07-24 19:15:38 +04:00
foreach ( $apps as $app ) {
if ( \OC_App :: shouldUpgrade ( $app )) {
2014-09-02 16:30:46 +04:00
$shouldUpgrade = true ;
break ;
2014-07-24 19:15:38 +04:00
}
}
2014-09-02 16:30:46 +04:00
return $shouldUpgrade ;
2014-06-10 20:01:07 +04:00
} else {
return false ;
}
}
2014-07-25 11:53:25 +04:00
2011-07-27 21:07:28 +04:00
}