2010-03-10 12:03:40 +00:00
< ? php
/**
2011-04-15 17:24:23 +00:00
* ownCloud
*
* @ author Frank Karlitschek
2012-05-26 17:14:24 +00:00
* @ copyright 2012 Frank Karlitschek frank @ owncloud . org
2011-04-15 17:24:23 +00:00
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
* License as published by the Free Software Foundation ; either
* version 3 of the License , or any later version .
*
* This library 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 along with this library . If not , see < http :// www . gnu . org / licenses />.
*
*/
2010-03-10 12:03:40 +00:00
2012-11-11 14:52:23 +00:00
require_once 'public/constants.php' ;
2011-08-02 16:31:42 +00:00
/**
* Class that is a namespace for all global OC variables
2011-08-06 09:36:56 +00:00
* No , we can not put this class in its own file because it is used by
* OC_autoload !
2011-08-02 16:31:42 +00:00
*/
class OC {
/**
* Assoziative array for autoloading . classname => filename
*/
public static $CLASSPATH = array ();
2011-08-02 16:48:19 +00:00
/**
2011-08-06 21:04:39 +00:00
* The installation path for owncloud on the server ( e . g . / srv / http / owncloud )
2011-08-02 16:48:19 +00:00
*/
public static $SERVERROOT = '' ;
/**
2011-08-06 21:04:39 +00:00
* the current request path relative to the owncloud root ( e . g . files / index . php )
2011-08-02 16:48:19 +00:00
*/
2012-05-11 19:31:51 +00:00
private static $SUBURI = '' ;
2011-08-02 16:48:19 +00:00
/**
2011-08-06 21:04:39 +00:00
* the owncloud root path for http requests ( e . g . owncloud / )
2011-08-02 16:48:19 +00:00
*/
public static $WEBROOT = '' ;
2012-02-23 14:37:38 +00:00
/**
* The installation path of the 3 rdparty folder on the server ( e . g . / srv / http / owncloud / 3 rdparty )
*/
public static $THIRDPARTYROOT = '' ;
/**
* the root path of the 3 rdparty folder for http requests ( e . g . owncloud / 3 rdparty )
*/
public static $THIRDPARTYWEBROOT = '' ;
2012-04-18 06:20:51 +00:00
/**
2012-09-07 12:05:51 +00:00
* The installation path array of the apps folder on the server ( e . g . / srv / http / owncloud ) 'path' and
2012-09-05 10:22:38 +00:00
* web path in 'url'
2012-04-18 06:20:51 +00:00
*/
2012-06-01 22:05:20 +00:00
public static $APPSROOTS = array ();
2012-04-18 06:20:51 +00:00
/*
* requested app
*/
public static $REQUESTEDAPP = '' ;
/*
* requested file of app
*/
public static $REQUESTEDFILE = '' ;
2012-05-22 18:22:53 +00:00
/**
* check if owncloud runs in cli mode
*/
public static $CLI = false ;
2012-08-02 15:47:38 +00:00
/*
* OC router
*/
protected static $router = null ;
2011-08-06 09:36:56 +00:00
/**
* SPL autoload
*/
2012-09-07 13:22:01 +00:00
public static function autoload ( $className ) {
2012-09-04 12:34:09 +00:00
if ( array_key_exists ( $className , OC :: $CLASSPATH )) {
2012-10-09 16:26:38 +00:00
$path = OC :: $CLASSPATH [ $className ];
2012-06-21 22:22:36 +00:00
/** @ TODO : Remove this when necessary
Remove " apps/ " from inclusion path for smooth migration to mutli app dir
*/
2012-10-09 16:26:38 +00:00
if ( strpos ( $path , 'apps/' ) === 0 ) {
OC_Log :: write ( 'core' , 'include path for class "' . $className . '" starts with "apps/"' , OC_Log :: DEBUG );
$path = str_replace ( 'apps/' , '' , $path );
}
2011-08-06 09:36:56 +00:00
}
2012-09-04 12:34:09 +00:00
elseif ( strpos ( $className , 'OC_' ) === 0 ) {
2012-09-04 12:42:58 +00:00
$path = strtolower ( str_replace ( '_' , '/' , substr ( $className , 3 )) . '.php' );
2011-08-06 09:36:56 +00:00
}
2012-09-07 16:30:48 +00:00
elseif ( strpos ( $className , 'OC\\' ) === 0 ) {
$path = strtolower ( str_replace ( '\\' , '/' , substr ( $className , 3 )) . '.php' );
}
2012-09-04 12:34:09 +00:00
elseif ( strpos ( $className , 'OCP\\' ) === 0 ) {
2012-09-04 12:54:38 +00:00
$path = 'public/' . strtolower ( str_replace ( '\\' , '/' , substr ( $className , 3 )) . '.php' );
2012-04-23 13:50:30 +00:00
}
2012-09-04 12:34:09 +00:00
elseif ( strpos ( $className , 'OCA\\' ) === 0 ) {
2012-09-04 12:42:58 +00:00
$path = 'apps/' . strtolower ( str_replace ( '\\' , '/' , substr ( $className , 3 )) . '.php' );
2012-07-20 15:42:32 +00:00
}
2012-09-04 12:34:09 +00:00
elseif ( strpos ( $className , 'Sabre_' ) === 0 ) {
$path = str_replace ( '_' , '/' , $className ) . '.php' ;
2011-09-18 18:57:05 +00:00
}
2012-10-27 09:32:16 +00:00
elseif ( strpos ( $className , 'Symfony\\Component\\Routing\\' ) === 0 ) {
$path = 'symfony/routing/' . str_replace ( '\\' , '/' , $className ) . '.php' ;
2012-07-21 17:43:50 +00:00
}
2012-10-17 10:25:34 +00:00
elseif ( strpos ( $className , 'Sabre\\VObject' ) === 0 ) {
2012-10-27 14:33:10 +00:00
$path = str_replace ( '\\' , '/' , $className ) . '.php' ;
2012-10-17 10:25:34 +00:00
}
2012-09-05 10:22:38 +00:00
elseif ( strpos ( $className , 'Test_' ) === 0 ) {
2012-09-04 12:42:58 +00:00
$path = 'tests/lib/' . strtolower ( str_replace ( '_' , '/' , substr ( $className , 5 )) . '.php' );
2012-09-22 12:51:34 +00:00
}
elseif ( strpos ( $className , 'Test\\' ) === 0 ) {
$path = 'tests/lib/' . strtolower ( str_replace ( '\\' , '/' , substr ( $className , 5 )) . '.php' );
2012-09-01 13:36:07 +00:00
} else {
return false ;
2012-02-12 17:06:32 +00:00
}
2012-09-07 12:05:51 +00:00
2012-09-04 12:34:09 +00:00
if ( $fullPath = stream_resolve_include_path ( $path )) {
2012-10-12 13:38:16 +00:00
require_once $fullPath ;
2012-08-31 23:46:31 +00:00
}
return false ;
2011-07-27 17:07:28 +00:00
}
2010-06-26 22:16:09 +00:00
2012-09-07 13:22:01 +00:00
public static function initPaths () {
2012-06-15 20:35:09 +00:00
// calculate the root directories
2012-09-28 13:29:41 +00:00
OC :: $SERVERROOT = str_replace ( " \\ " , '/' , substr ( __DIR__ , 0 , - 4 ));
2012-09-04 12:34:09 +00:00
OC :: $SUBURI = str_replace ( " \\ " , " / " , substr ( realpath ( $_SERVER [ " SCRIPT_FILENAME " ]), strlen ( OC :: $SERVERROOT )));
2011-09-18 18:57:05 +00:00
$scriptName = $_SERVER [ " SCRIPT_NAME " ];
2012-09-04 12:34:09 +00:00
if ( substr ( $scriptName , - 1 ) == '/' ) {
2011-09-18 18:57:05 +00:00
$scriptName .= 'index.php' ;
2012-02-26 03:09:48 +00:00
//make sure suburi follows the same rules as scriptName
2012-09-04 12:34:09 +00:00
if ( substr ( OC :: $SUBURI , - 9 ) != 'index.php' ) {
2012-09-04 12:46:43 +00:00
if ( substr ( OC :: $SUBURI , - 1 ) != '/' ) {
2012-02-26 03:09:48 +00:00
OC :: $SUBURI = OC :: $SUBURI . '/' ;
}
OC :: $SUBURI = OC :: $SUBURI . 'index.php' ;
}
2011-09-18 18:57:05 +00:00
}
2012-08-10 11:53:40 +00:00
2012-09-04 12:34:09 +00:00
OC :: $WEBROOT = substr ( $scriptName , 0 , strlen ( $scriptName ) - strlen ( OC :: $SUBURI ));
2012-02-23 14:37:38 +00:00
2012-09-04 12:34:09 +00:00
if ( OC :: $WEBROOT != '' and OC :: $WEBROOT [ 0 ] !== '/' ) {
2011-09-18 18:57:05 +00:00
OC :: $WEBROOT = '/' . OC :: $WEBROOT ;
}
2011-03-02 21:18:22 +00:00
2012-03-23 17:52:41 +00:00
// ensure we can find OC_Config
set_include_path (
OC :: $SERVERROOT . '/lib' . PATH_SEPARATOR .
get_include_path ()
);
2012-02-23 14:37:38 +00:00
// search the 3rdparty folder
2012-09-04 12:34:09 +00:00
if ( OC_Config :: getValue ( '3rdpartyroot' , '' ) <> '' and OC_Config :: getValue ( '3rdpartyurl' , '' ) <> '' ) {
2012-02-23 14:37:38 +00:00
OC :: $THIRDPARTYROOT = OC_Config :: getValue ( '3rdpartyroot' , '' );
OC :: $THIRDPARTYWEBROOT = OC_Config :: getValue ( '3rdpartyurl' , '' );
2012-09-04 12:34:09 +00:00
} elseif ( file_exists ( OC :: $SERVERROOT . '/3rdparty' )) {
2012-02-23 14:37:38 +00:00
OC :: $THIRDPARTYROOT = OC :: $SERVERROOT ;
OC :: $THIRDPARTYWEBROOT = OC :: $WEBROOT ;
2012-09-04 12:34:09 +00:00
} elseif ( file_exists ( OC :: $SERVERROOT . '/../3rdparty' )) {
2012-03-01 21:04:13 +00:00
OC :: $THIRDPARTYWEBROOT = rtrim ( dirname ( OC :: $WEBROOT ), '/' );
OC :: $THIRDPARTYROOT = rtrim ( dirname ( OC :: $SERVERROOT ), '/' );
2012-02-23 14:37:38 +00:00
} else {
echo ( " 3rdparty directory not found! Please put the ownCloud 3rdparty folder in the ownCloud folder or the folder above. You can also configure the location in the config.php file. " );
exit ;
}
2012-02-28 17:21:23 +00:00
// search the apps folder
2012-06-07 20:36:55 +00:00
$config_paths = OC_Config :: getValue ( 'apps_paths' , array ());
2012-09-04 12:34:09 +00:00
if ( ! empty ( $config_paths )) {
2012-06-07 20:36:55 +00:00
foreach ( $config_paths as $paths ) {
2012-06-25 13:50:27 +00:00
if ( isset ( $paths [ 'url' ]) && isset ( $paths [ 'path' ])) {
2012-09-04 12:34:09 +00:00
$paths [ 'url' ] = rtrim ( $paths [ 'url' ], '/' );
$paths [ 'path' ] = rtrim ( $paths [ 'path' ], '/' );
2012-06-25 13:50:27 +00:00
OC :: $APPSROOTS [] = $paths ;
}
2012-06-03 21:13:30 +00:00
}
2012-09-04 12:34:09 +00:00
} elseif ( file_exists ( OC :: $SERVERROOT . '/apps' )) {
2012-06-25 13:50:27 +00:00
OC :: $APPSROOTS [] = array ( 'path' => OC :: $SERVERROOT . '/apps' , 'url' => '/apps' , 'writable' => true );
2012-09-04 12:34:09 +00:00
} elseif ( file_exists ( OC :: $SERVERROOT . '/../apps' )) {
2012-06-25 13:50:27 +00:00
OC :: $APPSROOTS [] = array ( 'path' => rtrim ( dirname ( OC :: $SERVERROOT ), '/' ) . '/apps' , 'url' => '/apps' , 'writable' => true );
2012-06-01 22:05:20 +00:00
}
2012-06-03 21:13:30 +00:00
2012-09-04 12:34:09 +00:00
if ( empty ( OC :: $APPSROOTS )) {
2012-02-28 17:21:23 +00:00
echo ( " apps directory not found! Please put the ownCloud apps folder in the ownCloud folder or the folder above. You can also configure the location in the config.php file. " );
exit ;
}
2012-06-03 21:13:30 +00:00
$paths = array ();
foreach ( OC :: $APPSROOTS as $path )
$paths [] = $path [ 'path' ];
2012-02-23 14:37:38 +00:00
2011-09-18 18:57:05 +00:00
// set the right include path
2012-03-01 19:56:51 +00:00
set_include_path (
OC :: $SERVERROOT . '/lib' . PATH_SEPARATOR .
OC :: $SERVERROOT . '/config' . PATH_SEPARATOR .
OC :: $THIRDPARTYROOT . '/3rdparty' . PATH_SEPARATOR .
2012-10-22 22:28:12 +00:00
implode ( $paths , PATH_SEPARATOR ) . PATH_SEPARATOR .
2012-03-01 19:56:51 +00:00
get_include_path () . PATH_SEPARATOR .
OC :: $SERVERROOT
);
2012-03-19 20:42:59 +00:00
}
2011-04-16 10:18:42 +00:00
2012-03-19 20:42:59 +00:00
public static function checkInstalled () {
2012-02-11 22:37:35 +00:00
// Redirect to installer if not installed
2012-08-11 15:07:35 +00:00
if ( ! OC_Config :: getValue ( 'installed' , false ) && OC :: $SUBURI != '/index.php' ) {
2012-09-04 12:34:09 +00:00
if ( ! OC :: $CLI ) {
2012-08-11 15:07:35 +00:00
$url = 'http://' . $_SERVER [ 'SERVER_NAME' ] . OC :: $WEBROOT . '/index.php' ;
header ( " Location: $url " );
2012-08-09 06:55:51 +00:00
}
2012-02-11 22:37:35 +00:00
exit ();
}
2012-03-19 20:42:59 +00:00
}
2012-02-11 22:37:35 +00:00
2012-03-19 20:42:59 +00:00
public static function checkSSL () {
2011-09-18 18:57:05 +00:00
// redirect to https site if configured
2012-09-04 12:34:09 +00:00
if ( OC_Config :: getValue ( " forcessl " , false )) {
2012-10-10 16:56:14 +00:00
header ( 'Strict-Transport-Security: max-age=31536000' );
2011-09-23 11:52:10 +00:00
ini_set ( " session.cookie_secure " , " on " );
2012-08-06 20:16:45 +00:00
if ( OC_Request :: serverProtocol () <> 'https' and ! OC :: $CLI ) {
$url = " https:// " . OC_Request :: serverHost () . $_SERVER [ 'REQUEST_URI' ];
2011-09-18 18:57:05 +00:00
header ( " Location: $url " );
exit ();
}
}
2012-03-19 20:42:59 +00:00
}
2010-03-10 12:03:40 +00:00
2012-03-19 20:42:59 +00:00
public static function checkUpgrade () {
2012-09-04 12:34:09 +00:00
if ( OC_Config :: getValue ( 'installed' , false )) {
$installedVersion = OC_Config :: getValue ( 'version' , '0.0.0' );
$currentVersion = implode ( '.' , OC_Util :: getVersion ());
2012-01-08 12:01:41 +00:00
if ( version_compare ( $currentVersion , $installedVersion , '>' )) {
2012-10-29 21:03:18 +00:00
// Check if the .htaccess is existing - this is needed for upgrades from really old ownCloud versions
if ( isset ( $_SERVER [ 'SERVER_SOFTWARE' ]) && strstr ( $_SERVER [ 'SERVER_SOFTWARE' ], 'Apache' )) {
if ( ! OC_Util :: ishtaccessworking ()) {
2012-10-29 21:44:49 +00:00
if ( ! file_exists ( OC :: $SERVERROOT . '/data/.htaccess' )) {
2012-10-30 19:57:19 +00:00
OC_Setup :: protectDataDirectory ();
2012-10-29 21:44:49 +00:00
}
2012-10-29 21:03:18 +00:00
}
2012-11-11 14:52:23 +00:00
}
2012-09-04 12:34:09 +00:00
OC_Log :: write ( 'core' , 'starting upgrade from ' . $installedVersion . ' to ' . $currentVersion , OC_Log :: DEBUG );
2012-01-16 00:13:54 +00:00
$result = OC_DB :: updateDbFromStructure ( OC :: $SERVERROOT . '/db_structure.xml' );
2012-09-04 12:34:09 +00:00
if ( ! $result ) {
2012-01-16 00:13:54 +00:00
echo 'Error while upgrading the database' ;
die ();
}
2012-02-17 21:01:53 +00:00
if ( file_exists ( OC :: $SERVERROOT . " /config/config.php " ) and ! is_writable ( OC :: $SERVERROOT . " /config/config.php " )) {
$tmpl = new OC_Template ( '' , 'error' , 'guest' );
2012-11-04 10:10:46 +00:00
$tmpl -> assign ( 'errors' , array ( 1 => array ( 'error' => " Can't write into config directory 'config' " , 'hint' => " You can usually fix this by giving the webserver user write access to the config directory in owncloud " )));
2012-02-17 21:01:53 +00:00
$tmpl -> printPage ();
exit ;
}
2012-09-12 05:18:07 +00:00
$minimizerCSS = new OC_Minimizer_CSS ();
$minimizerCSS -> clearCache ();
$minimizerJS = new OC_Minimizer_JS ();
$minimizerJS -> clearCache ();
2012-09-04 12:34:09 +00:00
OC_Config :: setValue ( 'version' , implode ( '.' , OC_Util :: getVersion ()));
2012-06-16 18:50:52 +00:00
OC_App :: checkAppsRequirements ();
2012-06-26 18:41:11 +00:00
// load all apps to also upgrade enabled apps
OC_App :: loadApps ();
2012-01-08 12:01:41 +00:00
}
}
2012-03-19 20:42:59 +00:00
}
2012-03-30 21:31:05 +00:00
public static function initTemplateEngine () {
// Add the stuff we need always
2012-05-11 21:20:27 +00:00
OC_Util :: addScript ( " jquery-1.7.2.min " );
2012-03-30 21:31:05 +00:00
OC_Util :: addScript ( " jquery-ui-1.8.16.custom.min " );
OC_Util :: addScript ( " jquery-showpassword " );
OC_Util :: addScript ( " jquery.infieldlabel.min " );
OC_Util :: addScript ( " jquery-tipsy " );
OC_Util :: addScript ( " oc-dialogs " );
OC_Util :: addScript ( " js " );
OC_Util :: addScript ( " eventsource " );
OC_Util :: addScript ( " config " );
//OC_Util::addScript( "multiselect" );
2012-09-04 12:34:09 +00:00
OC_Util :: addScript ( 'search' , 'result' );
2012-10-05 07:42:36 +00:00
OC_Util :: addScript ( 'router' );
2012-08-08 23:02:05 +00:00
2012-09-05 10:22:38 +00:00
if ( OC_Config :: getValue ( 'installed' , false )) {
2012-09-04 12:34:09 +00:00
if ( OC_Appconfig :: getValue ( 'core' , 'backgroundjobs_mode' , 'ajax' ) == 'ajax' ) {
2012-08-10 11:53:40 +00:00
OC_Util :: addScript ( 'backgroundjobs' );
}
2012-08-08 23:02:05 +00:00
}
2012-08-29 06:38:33 +00:00
2012-03-30 21:31:05 +00:00
OC_Util :: addStyle ( " styles " );
OC_Util :: addStyle ( " multiselect " );
OC_Util :: addStyle ( " jquery-ui-1.8.16.custom " );
OC_Util :: addStyle ( " jquery-tipsy " );
}
public static function initSession () {
2012-10-14 18:47:31 +00:00
// prevents javascript from accessing php session cookies
2012-09-04 12:34:09 +00:00
ini_set ( 'session.cookie_httponly' , '1;' );
2012-10-14 18:47:31 +00:00
// (re)-initialize session
2012-03-30 21:31:05 +00:00
session_start ();
2012-11-11 14:52:23 +00:00
2012-10-14 18:47:31 +00:00
// regenerate session id periodically to avoid session fixation
if ( ! isset ( $_SESSION [ 'SID_CREATED' ])) {
$_SESSION [ 'SID_CREATED' ] = time ();
} else if ( time () - $_SESSION [ 'SID_CREATED' ] > 900 ) {
session_regenerate_id ( true );
$_SESSION [ 'SID_CREATED' ] = time ();
}
// session timeout
if ( isset ( $_SESSION [ 'LAST_ACTIVITY' ]) && ( time () - $_SESSION [ 'LAST_ACTIVITY' ] > 3600 )) {
if ( isset ( $_COOKIE [ session_name ()])) {
setcookie ( session_name (), '' , time () - 42000 , '/' );
}
session_unset ();
session_destroy ();
session_start ();
}
$_SESSION [ 'LAST_ACTIVITY' ] = time ();
2012-03-30 21:31:05 +00:00
}
2012-06-06 15:29:57 +00:00
2012-08-02 15:47:38 +00:00
public static function getRouter () {
if ( ! isset ( OC :: $router )) {
OC :: $router = new OC_Router ();
2012-08-02 15:59:18 +00:00
OC :: $router -> loadRoutes ();
2012-08-02 15:47:38 +00:00
}
return OC :: $router ;
}
2012-09-07 13:22:01 +00:00
public static function init () {
2012-03-19 20:42:59 +00:00
// register autoloader
2012-11-04 10:10:46 +00:00
spl_autoload_register ( array ( 'OC' , 'autoload' ));
2012-04-08 01:30:06 +00:00
setlocale ( LC_ALL , 'en_US.UTF-8' );
2012-06-06 15:29:57 +00:00
2012-03-19 20:42:59 +00:00
// set some stuff
//ob_start();
error_reporting ( E_ALL | E_STRICT );
2012-09-04 12:34:09 +00:00
if ( defined ( 'DEBUG' ) && DEBUG ) {
2012-03-19 20:42:59 +00:00
ini_set ( 'display_errors' , 1 );
}
2012-05-22 18:22:53 +00:00
self :: $CLI = ( php_sapi_name () == 'cli' );
2012-03-19 20:42:59 +00:00
2012-05-23 22:49:21 +00:00
date_default_timezone_set ( 'UTC' );
2012-09-04 12:34:09 +00:00
ini_set ( 'arg_separator.output' , '&' );
2012-03-19 20:42:59 +00:00
2012-06-01 10:41:38 +00:00
// try to switch magic quotes off.
2012-10-16 17:42:17 +00:00
if ( get_magic_quotes_gpc ()) {
2012-06-01 10:41:38 +00:00
@ set_magic_quotes_runtime ( false );
}
2012-04-01 15:02:32 +00:00
//try to configure php to enable big file uploads.
//this doesn´ t work always depending on the webserver and php configuration.
//Let´ s try to overwrite some defaults anyways
2012-06-06 15:29:57 +00:00
2012-04-01 15:02:32 +00:00
//try to set the maximum execution time to 60min
@ set_time_limit ( 3600 );
2012-09-04 12:34:09 +00:00
@ ini_set ( 'max_execution_time' , 3600 );
@ ini_set ( 'max_input_time' , 3600 );
2012-04-01 15:02:32 +00:00
//try to set the maximum filesize to 10G
2012-09-04 12:34:09 +00:00
@ ini_set ( 'upload_max_filesize' , '10G' );
@ ini_set ( 'post_max_size' , '10G' );
@ ini_set ( 'file_uploads' , '50' );
2012-04-01 15:02:32 +00:00
//try to set the session lifetime to 60min
2012-09-04 12:34:09 +00:00
@ ini_set ( 'gc_maxlifetime' , '3600' );
2012-04-01 15:02:32 +00:00
2012-11-09 12:30:07 +00:00
//copy http auth headers for apache+php-fcgid work around
if ( isset ( $_SERVER [ 'HTTP_XAUTHORIZATION' ]) && ! isset ( $_SERVER [ 'HTTP_AUTHORIZATION' ])) {
$_SERVER [ 'HTTP_AUTHORIZATION' ] = $_SERVER [ 'HTTP_XAUTHORIZATION' ];
}
2012-04-01 15:02:32 +00:00
2012-03-19 20:42:59 +00:00
//set http auth headers for apache+php-cgi work around
2012-09-04 12:34:09 +00:00
if ( isset ( $_SERVER [ 'HTTP_AUTHORIZATION' ]) && preg_match ( '/Basic\s+(.*)$/i' , $_SERVER [ 'HTTP_AUTHORIZATION' ], $matches )) {
2012-09-25 17:57:40 +00:00
list ( $name , $password ) = explode ( ':' , base64_decode ( $matches [ 1 ]), 2 );
2012-03-19 20:42:59 +00:00
$_SERVER [ 'PHP_AUTH_USER' ] = strip_tags ( $name );
$_SERVER [ 'PHP_AUTH_PW' ] = strip_tags ( $password );
}
//set http auth headers for apache+php-cgi work around if variable gets renamed by apache
2012-09-04 12:34:09 +00:00
if ( isset ( $_SERVER [ 'REDIRECT_HTTP_AUTHORIZATION' ]) && preg_match ( '/Basic\s+(.*)$/i' , $_SERVER [ 'REDIRECT_HTTP_AUTHORIZATION' ], $matches )) {
2012-09-25 17:57:40 +00:00
list ( $name , $password ) = explode ( ':' , base64_decode ( $matches [ 1 ]), 2 );
2012-03-19 20:42:59 +00:00
$_SERVER [ 'PHP_AUTH_USER' ] = strip_tags ( $name );
$_SERVER [ 'PHP_AUTH_PW' ] = strip_tags ( $password );
}
2012-06-06 15:29:57 +00:00
2012-03-23 17:52:41 +00:00
self :: initPaths ();
2012-03-19 20:42:59 +00:00
2012-09-26 11:38:06 +00:00
register_shutdown_function ( array ( 'OC_Log' , 'onShutdown' ));
set_error_handler ( array ( 'OC_Log' , 'onError' ));
set_exception_handler ( array ( 'OC_Log' , 'onException' ));
2012-09-12 19:30:04 +00:00
2012-09-01 18:51:48 +00:00
// set debug mode if an xdebug session is active
2012-09-04 12:34:09 +00:00
if ( ! defined ( 'DEBUG' ) || ! DEBUG ) {
if ( isset ( $_COOKIE [ 'XDEBUG_SESSION' ])) {
2012-09-05 10:22:38 +00:00
define ( 'DEBUG' , true );
2012-09-01 18:51:48 +00:00
}
}
2012-03-19 20:42:59 +00:00
// register the stream wrappers
2012-09-04 12:34:09 +00:00
require_once 'streamwrappers.php' ;
2012-03-19 20:42:59 +00:00
stream_wrapper_register ( " fakedir " , " OC_FakeDirStream " );
stream_wrapper_register ( 'static' , 'OC_StaticStreamWrapper' );
stream_wrapper_register ( 'close' , 'OC_CloseStreamWrapper' );
self :: checkInstalled ();
self :: checkSSL ();
2012-03-30 21:31:05 +00:00
self :: initSession ();
2012-08-11 15:07:35 +00:00
self :: initTemplateEngine ();
2012-03-30 21:33:36 +00:00
self :: checkUpgrade ();
2011-09-18 18:57:05 +00:00
$errors = OC_Util :: checkServer ();
if ( count ( $errors ) > 0 ) {
OC_Template :: printGuestPage ( '' , 'error' , array ( 'errors' => $errors ));
exit ;
}
2011-08-06 21:19:00 +00:00
2011-09-18 18:57:05 +00:00
// User and Groups
2012-09-04 12:34:09 +00:00
if ( ! OC_Config :: getValue ( " installed " , false )) {
2011-09-18 18:57:05 +00:00
$_SESSION [ 'user_id' ] = '' ;
}
2012-03-01 17:44:26 +00:00
2012-07-19 14:31:55 +00:00
OC_User :: useBackend ( new OC_User_Database ());
2012-04-12 23:58:53 +00:00
OC_Group :: useBackend ( new OC_Group_Database ());
2011-07-30 22:23:06 +00:00
2012-10-08 11:35:59 +00:00
if ( isset ( $_SERVER [ 'PHP_AUTH_USER' ]) && isset ( $_SESSION [ 'user_id' ]) && $_SERVER [ 'PHP_AUTH_USER' ] != $_SESSION [ 'user_id' ]) {
OC_User :: logout ();
}
2011-10-18 19:19:13 +00:00
// Load Apps
// This includes plugins for users and filesystems as well
global $RUNTIME_NOAPPS ;
2012-03-30 12:39:07 +00:00
global $RUNTIME_APPTYPES ;
2012-09-04 12:34:09 +00:00
if ( ! $RUNTIME_NOAPPS ) {
if ( $RUNTIME_APPTYPES ) {
2012-03-30 12:39:07 +00:00
OC_App :: loadApps ( $RUNTIME_APPTYPES );
} else {
OC_App :: loadApps ();
}
2011-10-18 19:19:13 +00:00
}
2012-06-06 15:29:57 +00:00
2012-09-01 00:48:54 +00:00
//setup extra user backends
OC_User :: setupBackends ();
2012-08-28 21:07:09 +00:00
// register cache cleanup jobs
2012-08-28 20:39:05 +00:00
OC_BackgroundJob_RegularTask :: register ( 'OC_Cache_FileGlobal' , 'gc' );
2012-08-28 21:07:09 +00:00
OC_Hook :: connect ( 'OC_User' , 'post_login' , 'OC_Cache_File' , 'loginListener' );
2012-08-28 20:39:05 +00:00
2012-04-03 22:31:34 +00:00
// Check for blacklisted files
2012-09-05 10:22:38 +00:00
OC_Hook :: connect ( 'OC_Filesystem' , 'write' , 'OC_Filesystem' , 'isBlacklisted' );
2012-08-11 15:04:04 +00:00
OC_Hook :: connect ( 'OC_Filesystem' , 'rename' , 'OC_Filesystem' , 'isBlacklisted' );
2011-10-18 19:19:13 +00:00
2012-02-28 10:16:19 +00:00
//make sure temporary files are cleaned up
2012-11-04 10:10:46 +00:00
register_shutdown_function ( array ( 'OC_Helper' , 'cleanTmp' ));
2012-06-05 15:45:09 +00:00
2012-04-26 19:56:29 +00:00
//parse the given parameters
2012-06-08 20:30:02 +00:00
self :: $REQUESTEDAPP = ( isset ( $_GET [ 'app' ]) && trim ( $_GET [ 'app' ]) != '' && ! is_null ( $_GET [ 'app' ]) ? str_replace ( array ( '\0' , '/' , '\\' , '..' ), '' , strip_tags ( $_GET [ 'app' ])) : OC_Config :: getValue ( 'defaultapp' , 'files' ));
2012-09-04 12:34:09 +00:00
if ( substr_count ( self :: $REQUESTEDAPP , '?' ) != 0 ) {
2012-04-27 20:22:03 +00:00
$app = substr ( self :: $REQUESTEDAPP , 0 , strpos ( self :: $REQUESTEDAPP , '?' ));
2012-08-06 19:45:02 +00:00
$param = substr ( $_GET [ 'app' ], strpos ( $_GET [ 'app' ], '?' ) + 1 );
2012-04-27 20:22:03 +00:00
parse_str ( $param , $get );
$_GET = array_merge ( $_GET , $get );
self :: $REQUESTEDAPP = $app ;
$_GET [ 'app' ] = $app ;
}
2012-04-26 15:55:00 +00:00
self :: $REQUESTEDFILE = ( isset ( $_GET [ 'getfile' ]) ? $_GET [ 'getfile' ] : null );
2012-09-04 12:34:09 +00:00
if ( substr_count ( self :: $REQUESTEDFILE , '?' ) != 0 ) {
2012-04-23 15:09:28 +00:00
$file = substr ( self :: $REQUESTEDFILE , 0 , strpos ( self :: $REQUESTEDFILE , '?' ));
$param = substr ( self :: $REQUESTEDFILE , strpos ( self :: $REQUESTEDFILE , '?' ) + 1 );
2012-04-23 18:11:21 +00:00
parse_str ( $param , $get );
$_GET = array_merge ( $_GET , $get );
2012-04-23 15:09:28 +00:00
self :: $REQUESTEDFILE = $file ;
$_GET [ 'getfile' ] = $file ;
2012-04-19 20:25:21 +00:00
}
2012-09-04 12:34:09 +00:00
if ( ! is_null ( self :: $REQUESTEDFILE )) {
2012-06-01 22:05:20 +00:00
$subdir = OC_App :: getAppPath ( OC :: $REQUESTEDAPP ) . '/' . self :: $REQUESTEDFILE ;
$parent = OC_App :: getAppPath ( OC :: $REQUESTEDAPP );
2012-09-04 12:34:09 +00:00
if ( ! OC_Helper :: issubdirectory ( $subdir , $parent )) {
2012-04-26 15:55:00 +00:00
self :: $REQUESTEDFILE = null ;
2012-04-26 16:08:49 +00:00
header ( 'HTTP/1.0 404 Not Found' );
2012-04-26 15:55:00 +00:00
exit ;
}
}
2011-09-18 18:57:05 +00:00
}
2012-08-08 19:08:20 +00:00
/**
2012-08-10 10:17:13 +00:00
* @ brief Handle the request
2012-08-08 19:08:20 +00:00
*/
public static function handleRequest () {
2012-08-11 15:07:35 +00:00
if ( ! OC_Config :: getValue ( 'installed' , false )) {
2012-10-30 19:56:31 +00:00
require_once 'core/setup.php' ;
2012-08-11 15:07:35 +00:00
exit ();
}
2012-08-08 19:08:20 +00:00
// Handle WebDAV
2012-09-04 12:34:09 +00:00
if ( $_SERVER [ 'REQUEST_METHOD' ] == 'PROPFIND' ) {
2012-08-08 19:08:20 +00:00
header ( 'location: ' . OC_Helper :: linkToRemote ( 'webdav' ));
2012-08-10 10:17:13 +00:00
return ;
2012-08-08 19:08:20 +00:00
}
2012-08-10 23:00:26 +00:00
try {
2012-11-15 13:48:06 +00:00
OC_App :: loadApps ();
2012-08-10 23:00:26 +00:00
OC :: getRouter () -> match ( OC_Request :: getPathInfo ());
return ;
} catch ( Symfony\Component\Routing\Exception\ResourceNotFoundException $e ) {
//header('HTTP/1.0 404 Not Found');
} catch ( Symfony\Component\Routing\Exception\MethodNotAllowedException $e ) {
OC_Response :: setStatus ( 405 );
return ;
}
2012-08-12 14:16:22 +00:00
$app = OC :: $REQUESTEDAPP ;
$file = OC :: $REQUESTEDFILE ;
$param = array ( 'app' => $app , 'file' => $file );
2012-08-10 10:17:13 +00:00
// Handle app css files
2012-09-07 13:42:37 +00:00
if ( substr ( $file , - 3 ) == 'css' ) {
2012-08-12 14:16:22 +00:00
self :: loadCSSFile ( $param );
2012-08-10 10:17:13 +00:00
return ;
2012-08-08 19:08:20 +00:00
}
// Someone is logged in :
if ( OC_User :: isLoggedIn ()) {
OC_App :: loadApps ();
2012-09-01 00:48:54 +00:00
OC_User :: setupBackends ();
2012-08-08 19:08:20 +00:00
if ( isset ( $_GET [ " logout " ]) and ( $_GET [ " logout " ])) {
2012-09-04 16:07:38 +00:00
OC_Preferences :: deleteKey ( OC_User :: getUser (), 'login_token' , $_COOKIE [ 'oc_token' ]);
2012-08-08 19:08:20 +00:00
OC_User :: logout ();
header ( " Location: " . OC :: $WEBROOT . '/' );
} else {
2012-08-10 10:27:37 +00:00
if ( is_null ( $file )) {
2012-08-12 14:16:22 +00:00
$param [ 'file' ] = 'index.php' ;
2012-08-10 10:27:37 +00:00
}
2012-08-12 14:16:22 +00:00
$file_ext = substr ( $param [ 'file' ], - 3 );
2012-08-10 10:27:37 +00:00
if ( $file_ext != 'php'
2012-11-04 17:36:16 +00:00
|| ! self :: loadAppScriptFile ( $param )) {
2012-08-10 10:27:37 +00:00
header ( 'HTTP/1.0 404 Not Found' );
2012-08-08 19:08:20 +00:00
}
}
2012-08-10 10:17:13 +00:00
return ;
2012-08-08 19:08:20 +00:00
}
2012-08-10 10:17:13 +00:00
// Not handled and not logged in
self :: handleLogin ();
2012-08-08 19:08:20 +00:00
}
2012-08-12 14:16:22 +00:00
public static function loadAppScriptFile ( $param ) {
2012-08-12 14:52:36 +00:00
OC_App :: loadApps ();
2012-08-12 14:16:22 +00:00
$app = $param [ 'app' ];
$file = $param [ 'file' ];
2012-08-09 22:58:13 +00:00
$app_path = OC_App :: getAppPath ( $app );
2012-08-10 10:27:37 +00:00
$file = $app_path . '/' . $file ;
unset ( $app , $app_path );
if ( file_exists ( $file )) {
2012-09-04 12:34:09 +00:00
require_once $file ;
2012-08-10 10:27:37 +00:00
return true ;
2012-08-09 22:58:13 +00:00
}
2012-08-10 10:27:37 +00:00
return false ;
2012-08-09 22:58:13 +00:00
}
2012-08-12 14:16:22 +00:00
public static function loadCSSFile ( $param ) {
$app = $param [ 'app' ];
$file = $param [ 'file' ];
2012-08-09 22:58:57 +00:00
$app_path = OC_App :: getAppPath ( $app );
if ( file_exists ( $app_path . '/' . $file )) {
$app_web_path = OC_App :: getAppWebPath ( $app );
$filepath = $app_web_path . '/' . $file ;
$minimizer = new OC_Minimizer_CSS ();
$info = array ( $app_path , $app_web_path , $file );
$minimizer -> output ( array ( $info ), $filepath );
}
}
2012-08-10 10:17:13 +00:00
protected static function handleLogin () {
2012-09-01 00:48:54 +00:00
OC_App :: loadApps ( array ( 'prelogin' ));
2012-10-12 14:12:43 +00:00
$error = array ();
2012-08-10 10:17:13 +00:00
// remember was checked after last login
if ( OC :: tryRememberLogin ()) {
2012-10-12 14:12:43 +00:00
$error [] = 'invalidcookie' ;
2012-08-10 10:17:13 +00:00
// Someone wants to log in :
} elseif ( OC :: tryFormLogin ()) {
2012-10-12 14:12:43 +00:00
$error [] = 'invalidpassword' ;
2012-08-29 06:38:33 +00:00
2012-08-10 10:17:13 +00:00
// The user is already authenticated using Apaches AuthType Basic... very usable in combination with LDAP
} elseif ( OC :: tryBasicAuthLogin ()) {
2012-10-12 14:12:43 +00:00
$error [] = 'invalidpassword' ;
2012-08-10 10:17:13 +00:00
}
2012-10-12 14:12:43 +00:00
OC_Util :: displayLoginPage ( array_unique ( $error ));
2012-08-10 10:17:13 +00:00
}
2012-09-04 18:36:26 +00:00
protected static function cleanupLoginTokens ( $user ) {
2012-09-05 15:33:15 +00:00
$cutoff = time () - OC_Config :: getValue ( 'remember_login_cookie_lifetime' , 60 * 60 * 24 * 15 );
2012-10-11 12:11:30 +00:00
$tokens = OC_Preferences :: getKeys ( $user , 'login_token' );
2012-09-04 18:36:26 +00:00
foreach ( $tokens as $token ) {
$time = OC_Preferences :: getValue ( $user , 'login_token' , $token );
if ( $time < $cutoff ) {
OC_Preferences :: deleteKey ( $user , 'login_token' , $token );
}
2012-08-10 10:17:13 +00:00
}
}
protected static function tryRememberLogin () {
2012-08-08 20:42:45 +00:00
if ( ! isset ( $_COOKIE [ " oc_remember_login " ])
2012-09-04 12:34:09 +00:00
|| ! isset ( $_COOKIE [ " oc_token " ])
|| ! isset ( $_COOKIE [ " oc_username " ])
2012-11-04 17:36:16 +00:00
|| ! $_COOKIE [ " oc_remember_login " ]) {
2012-08-08 20:42:45 +00:00
return false ;
}
OC_App :: loadApps ( array ( 'authentication' ));
if ( defined ( " DEBUG " ) && DEBUG ) {
2012-09-04 12:34:09 +00:00
OC_Log :: write ( 'core' , 'Trying to login from cookie' , OC_Log :: DEBUG );
2012-08-08 20:42:45 +00:00
}
// confirm credentials in cookie
2012-09-04 16:07:38 +00:00
if ( isset ( $_COOKIE [ 'oc_token' ]) && OC_User :: userExists ( $_COOKIE [ 'oc_username' ])) {
2012-10-11 09:38:42 +00:00
// delete outdated cookies
2012-10-11 10:30:43 +00:00
self :: cleanupLoginTokens ( $_COOKIE [ 'oc_username' ]);
// get stored tokens
2012-09-04 16:07:38 +00:00
$tokens = OC_Preferences :: getKeys ( $_COOKIE [ 'oc_username' ], 'login_token' );
2012-10-11 09:38:42 +00:00
// test cookies token against stored tokens
2012-09-04 16:07:38 +00:00
if ( in_array ( $_COOKIE [ 'oc_token' ], $tokens , true )) {
2012-10-11 09:38:42 +00:00
// replace successfully used token with a new one
2012-10-11 12:11:30 +00:00
OC_Preferences :: deleteKey ( $_COOKIE [ 'oc_username' ], 'login_token' , $_COOKIE [ 'oc_token' ]);
2012-10-15 18:00:33 +00:00
$token = OC_Util :: generate_random_bytes ( 32 );
2012-10-11 12:11:30 +00:00
OC_Preferences :: setValue ( $_COOKIE [ 'oc_username' ], 'login_token' , $token , time ());
OC_User :: setMagicInCookie ( $_COOKIE [ 'oc_username' ], $token );
2012-10-11 09:38:42 +00:00
// login
2012-09-04 16:07:38 +00:00
OC_User :: setUserId ( $_COOKIE [ 'oc_username' ]);
OC_Util :: redirectToDefaultPage ();
// doesn't return
}
2012-11-04 21:16:04 +00:00
// if you reach this point you have changed your password
2012-10-11 09:54:40 +00:00
// or you are an attacker
2012-11-04 21:16:04 +00:00
// we can not delete tokens here because users may reach
2012-10-12 09:12:31 +00:00
// this point multiple times after a password change
2012-10-11 12:12:19 +00:00
OC_Log :: write ( 'core' , 'Authentication cookie rejected for user ' . $_COOKIE [ 'oc_username' ], OC_Log :: WARN );
2012-08-08 20:42:45 +00:00
}
2012-09-04 16:07:38 +00:00
OC_User :: unsetMagicInCookie ();
2012-08-08 20:42:45 +00:00
return true ;
}
2012-08-10 10:17:13 +00:00
protected static function tryFormLogin () {
2012-09-29 13:18:38 +00:00
if ( ! isset ( $_POST [ " user " ]) || ! isset ( $_POST [ 'password' ])) {
2012-08-08 20:42:45 +00:00
return false ;
}
2012-09-01 00:48:54 +00:00
2012-08-08 20:42:45 +00:00
OC_App :: loadApps ();
2012-09-07 12:05:51 +00:00
2012-09-01 00:48:54 +00:00
//setup extra user backends
OC_User :: setupBackends ();
2012-09-07 12:05:51 +00:00
2012-08-08 20:42:45 +00:00
if ( OC_User :: login ( $_POST [ " user " ], $_POST [ " password " ])) {
2012-09-04 18:36:26 +00:00
self :: cleanupLoginTokens ( $_POST [ 'user' ]);
2012-09-04 12:34:09 +00:00
if ( ! empty ( $_POST [ " remember_login " ])) {
2012-08-08 20:42:45 +00:00
if ( defined ( " DEBUG " ) && DEBUG ) {
2012-09-04 12:34:09 +00:00
OC_Log :: write ( 'core' , 'Setting remember login to cookie' , OC_Log :: DEBUG );
2012-08-08 20:42:45 +00:00
}
2012-10-15 18:00:33 +00:00
$token = OC_Util :: generate_random_bytes ( 32 );
2012-09-04 16:07:38 +00:00
OC_Preferences :: setValue ( $_POST [ 'user' ], 'login_token' , $token , time ());
2012-08-08 20:42:45 +00:00
OC_User :: setMagicInCookie ( $_POST [ " user " ], $token );
}
else {
OC_User :: unsetMagicInCookie ();
}
2012-09-30 01:47:37 +00:00
header ( 'Location: ' . $_SERVER [ 'REQUEST_URI' ] );
exit ();
2012-08-08 20:42:45 +00:00
}
return true ;
}
2012-08-10 10:17:13 +00:00
protected static function tryBasicAuthLogin () {
2012-08-08 20:42:45 +00:00
if ( ! isset ( $_SERVER [ " PHP_AUTH_USER " ])
2012-09-07 13:22:01 +00:00
|| ! isset ( $_SERVER [ " PHP_AUTH_PW " ])) {
2012-08-29 18:34:44 +00:00
return false ;
2012-08-08 20:42:45 +00:00
}
OC_App :: loadApps ( array ( 'authentication' ));
2012-09-05 10:22:38 +00:00
if ( OC_User :: login ( $_SERVER [ " PHP_AUTH_USER " ], $_SERVER [ " PHP_AUTH_PW " ])) {
2012-11-04 10:10:46 +00:00
//OC_Log::write('core',"Logged in with HTTP Authentication", OC_Log::DEBUG);
2012-08-08 20:42:45 +00:00
OC_User :: unsetMagicInCookie ();
$_REQUEST [ 'redirect_url' ] = ( isset ( $_SERVER [ 'REQUEST_URI' ]) ? $_SERVER [ 'REQUEST_URI' ] : '' );
OC_Util :: redirectToDefaultPage ();
}
return true ;
}
2011-03-02 21:18:22 +00:00
}
2010-03-10 12:03:40 +00:00
2011-09-18 18:57:05 +00:00
// define runtime variables - unless this already has been done
2012-09-04 12:34:09 +00:00
if ( ! isset ( $RUNTIME_NOAPPS )) {
2011-09-18 18:57:05 +00:00
$RUNTIME_NOAPPS = false ;
2011-07-29 19:03:53 +00:00
}
2011-10-19 21:38:35 +00:00
if ( ! function_exists ( 'get_temp_dir' )) {
function get_temp_dir () {
if ( $temp = ini_get ( 'upload_tmp_dir' ) ) return $temp ;
if ( $temp = getenv ( 'TMP' ) ) return $temp ;
if ( $temp = getenv ( 'TEMP' ) ) return $temp ;
if ( $temp = getenv ( 'TMPDIR' ) ) return $temp ;
2012-09-04 12:34:09 +00:00
$temp = tempnam ( __FILE__ , '' );
2011-10-19 21:38:35 +00:00
if ( file_exists ( $temp )) {
unlink ( $temp );
return dirname ( $temp );
}
2011-11-22 00:48:08 +00:00
if ( $temp = sys_get_temp_dir ()) return $temp ;
2012-06-06 15:29:57 +00:00
2011-10-19 21:38:35 +00:00
return null ;
}
2011-07-29 19:03:53 +00:00
}
2011-11-13 15:16:21 +00:00
OC :: init ();