2010-03-10 15:03:40 +03:00
< ? php
/**
2011-04-15 21:24:23 +04:00
* ownCloud
*
* @ author Frank Karlitschek
2012-05-26 21:14:24 +04:00
* @ copyright 2012 Frank Karlitschek frank @ owncloud . org
2011-04-15 21:24:23 +04: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 .
2014-04-27 18:41:09 +04:00
*
2011-04-15 21:24:23 +04:00
* 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 15:03:40 +03:00
2012-11-11 18:52:23 +04:00
require_once 'public/constants.php' ;
2011-08-02 20:31:42 +04:00
/**
* Class that is a namespace for all global OC variables
2011-08-06 13:36:56 +04:00
* No , we can not put this class in its own file because it is used by
* OC_autoload !
2011-08-02 20:31:42 +04:00
*/
2013-01-31 01:55:33 +04:00
class OC {
2013-01-14 23:30:28 +04:00
/**
2013-01-18 22:52:29 +04:00
* Associative array for autoloading . classname => filename
2013-01-14 23:30:28 +04:00
*/
public static $CLASSPATH = array ();
/**
* The installation path for owncloud on the server ( e . g . / srv / http / owncloud )
*/
public static $SERVERROOT = '' ;
/**
* the current request path relative to the owncloud root ( e . g . files / index . php )
*/
private static $SUBURI = '' ;
/**
* the owncloud root path for http requests ( e . g . owncloud / )
*/
public static $WEBROOT = '' ;
/**
* 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 = '' ;
/**
* The installation path array of the apps folder on the server ( e . g . / srv / http / owncloud ) 'path' and
* web path in 'url'
*/
public static $APPSROOTS = array ();
2014-01-17 17:40:48 +04:00
public static $configDir ;
2014-05-10 16:00:22 +04:00
/**
2013-01-14 23:30:28 +04:00
* requested app
*/
public static $REQUESTEDAPP = '' ;
2014-05-10 16:00:22 +04:00
2013-01-14 23:30:28 +04:00
/**
2014-11-26 15:16:22 +03:00
* check if ownCloud runs in cli mode
2013-01-14 23:30:28 +04:00
*/
public static $CLI = false ;
2013-10-07 02:32:08 +04:00
2013-01-14 23:30:28 +04:00
/**
2013-05-08 00:16:02 +04:00
* @ var \OC\Autoloader $loader
2013-01-14 23:30:28 +04:00
*/
2013-05-08 00:16:02 +04:00
public static $loader = null ;
2013-01-14 23:30:28 +04:00
2013-08-21 02:58:15 +04:00
/**
* @ var \OC\Server
*/
public static $server = null ;
2013-01-31 01:55:33 +04:00
public static function initPaths () {
2013-01-14 23:30:28 +04:00
// calculate the root directories
OC :: $SERVERROOT = str_replace ( " \\ " , '/' , substr ( __DIR__ , 0 , - 4 ));
2013-02-02 13:02:10 +04:00
// ensure we can find OC_Config
set_include_path (
OC :: $SERVERROOT . '/lib' . PATH_SEPARATOR .
2013-07-02 19:45:34 +04:00
get_include_path ()
2013-02-02 13:02:10 +04:00
);
2014-03-13 16:33:09 +04:00
if ( defined ( 'PHPUNIT_CONFIG_DIR' )) {
self :: $configDir = OC :: $SERVERROOT . '/' . PHPUNIT_CONFIG_DIR . '/' ;
} elseif ( defined ( 'PHPUNIT_RUN' ) and PHPUNIT_RUN and is_dir ( OC :: $SERVERROOT . '/tests/config/' )) {
2014-01-20 16:41:52 +04:00
self :: $configDir = OC :: $SERVERROOT . '/tests/config/' ;
2014-01-17 17:40:48 +04:00
} else {
self :: $configDir = OC :: $SERVERROOT . '/config/' ;
}
OC_Config :: $object = new \OC\Config ( self :: $configDir );
2013-01-14 23:30:28 +04:00
OC :: $SUBURI = str_replace ( " \\ " , " / " , substr ( realpath ( $_SERVER [ " SCRIPT_FILENAME " ]), strlen ( OC :: $SERVERROOT )));
2012-09-09 14:54:47 +04:00
$scriptName = OC_Request :: scriptName ();
2013-01-14 23:30:28 +04:00
if ( substr ( $scriptName , - 1 ) == '/' ) {
$scriptName .= 'index.php' ;
//make sure suburi follows the same rules as scriptName
if ( substr ( OC :: $SUBURI , - 9 ) != 'index.php' ) {
if ( substr ( OC :: $SUBURI , - 1 ) != '/' ) {
OC :: $SUBURI = OC :: $SUBURI . '/' ;
}
OC :: $SUBURI = OC :: $SUBURI . 'index.php' ;
}
}
2014-07-07 17:01:02 +04:00
if ( substr ( $scriptName , 0 - strlen ( OC :: $SUBURI )) === OC :: $SUBURI ) {
OC :: $WEBROOT = substr ( $scriptName , 0 , 0 - strlen ( OC :: $SUBURI ));
2013-01-14 23:30:28 +04:00
2014-07-07 17:01:02 +04:00
if ( OC :: $WEBROOT != '' && OC :: $WEBROOT [ 0 ] !== '/' ) {
OC :: $WEBROOT = '/' . OC :: $WEBROOT ;
}
} else {
// The scriptName is not ending with OC::$SUBURI
// This most likely means that we are calling from CLI.
// However some cron jobs still need to generate
// a web URL, so we use overwritewebroot as a fallback.
OC :: $WEBROOT = OC_Config :: getValue ( 'overwritewebroot' , '' );
2013-01-14 23:30:28 +04:00
}
// search the 3rdparty folder
2014-07-29 23:07:12 +04:00
OC :: $THIRDPARTYROOT = OC_Config :: getValue ( '3rdpartyroot' , null );
OC :: $THIRDPARTYWEBROOT = OC_Config :: getValue ( '3rdpartyurl' , null );
2014-07-31 01:21:40 +04:00
if ( empty ( OC :: $THIRDPARTYROOT ) && empty ( OC :: $THIRDPARTYWEBROOT )) {
2014-07-29 23:07:12 +04:00
if ( file_exists ( OC :: $SERVERROOT . '/3rdparty' )) {
OC :: $THIRDPARTYROOT = OC :: $SERVERROOT ;
OC :: $THIRDPARTYWEBROOT = OC :: $WEBROOT ;
} elseif ( file_exists ( OC :: $SERVERROOT . '/../3rdparty' )) {
OC :: $THIRDPARTYWEBROOT = rtrim ( dirname ( OC :: $WEBROOT ), '/' );
OC :: $THIRDPARTYROOT = rtrim ( dirname ( OC :: $SERVERROOT ), '/' );
}
}
2014-07-31 01:21:40 +04:00
if ( empty ( OC :: $THIRDPARTYROOT ) || ! file_exists ( OC :: $THIRDPARTYROOT )) {
2014-07-29 23:07:12 +04:00
echo ( '3rdparty directory not found! Please put the ownCloud 3rdparty'
2013-12-13 16:30:29 +04:00
. ' folder in the ownCloud folder or the folder above.'
. ' You can also configure the location in the config.php file.' );
2014-07-29 23:45:24 +04:00
return ;
2013-01-14 23:30:28 +04:00
}
2014-07-29 23:07:12 +04:00
2013-01-14 23:30:28 +04:00
// search the apps folder
$config_paths = OC_Config :: getValue ( 'apps_paths' , array ());
if ( ! empty ( $config_paths )) {
foreach ( $config_paths as $paths ) {
if ( isset ( $paths [ 'url' ]) && isset ( $paths [ 'path' ])) {
$paths [ 'url' ] = rtrim ( $paths [ 'url' ], '/' );
$paths [ 'path' ] = rtrim ( $paths [ 'path' ], '/' );
OC :: $APPSROOTS [] = $paths ;
}
}
} elseif ( file_exists ( OC :: $SERVERROOT . '/apps' )) {
OC :: $APPSROOTS [] = array ( 'path' => OC :: $SERVERROOT . '/apps' , 'url' => '/apps' , 'writable' => true );
} elseif ( file_exists ( OC :: $SERVERROOT . '/../apps' )) {
2013-02-11 20:44:02 +04:00
OC :: $APPSROOTS [] = array (
'path' => rtrim ( dirname ( OC :: $SERVERROOT ), '/' ) . '/apps' ,
'url' => '/apps' ,
'writable' => true
);
2013-01-14 23:30:28 +04:00
}
if ( empty ( OC :: $APPSROOTS )) {
2013-07-17 00:36:39 +04:00
throw new Exception ( 'apps directory not found! Please put the ownCloud apps folder in the ownCloud folder'
2013-12-13 16:30:29 +04:00
. ' or the folder above. You can also configure the location in the config.php file.' );
2013-01-14 23:30:28 +04:00
}
$paths = array ();
2013-01-31 01:55:33 +04:00
foreach ( OC :: $APPSROOTS as $path ) {
2013-01-14 23:30:28 +04:00
$paths [] = $path [ 'path' ];
2013-01-31 01:55:33 +04:00
}
2013-01-14 23:30:28 +04:00
// set the right include path
set_include_path (
2013-09-25 15:36:30 +04:00
OC :: $SERVERROOT . '/lib/private' . PATH_SEPARATOR .
2013-07-02 19:45:34 +04:00
OC :: $SERVERROOT . '/config' . PATH_SEPARATOR .
OC :: $THIRDPARTYROOT . '/3rdparty' . PATH_SEPARATOR .
2014-05-13 02:16:18 +04:00
implode ( PATH_SEPARATOR , $paths ) . PATH_SEPARATOR .
2013-07-02 19:45:34 +04:00
get_include_path () . PATH_SEPARATOR .
OC :: $SERVERROOT
2013-01-14 23:30:28 +04:00
);
}
2012-12-20 14:10:45 +04:00
2013-01-03 23:11:00 +04:00
public static function checkConfig () {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2014-12-05 19:32:19 +03:00
// Create config in case it does not already exists
$configFilePath = self :: $configDir . '/config.php' ;
if ( ! file_exists ( $configFilePath )) {
@ touch ( $configFilePath );
}
// Check if config is writable
$configFileWritable = is_writable ( $configFilePath );
2014-11-25 18:12:12 +03:00
if ( ! $configFileWritable && ! OC_Helper :: isReadOnlyConfigEnabled ()
|| ! $configFileWritable && \OCP\Util :: needUpgrade ()) {
2013-11-25 16:04:23 +04:00
if ( self :: $CLI ) {
2014-05-29 03:21:54 +04:00
echo $l -> t ( 'Cannot write into "config" directory!' ) . " \n " ;
echo $l -> t ( 'This can usually be fixed by giving the webserver write access to the config directory' ) . " \n " ;
2013-11-25 16:04:23 +04:00
echo " \n " ;
2014-05-29 03:21:54 +04:00
echo $l -> t ( 'See %s' , array ( \OC_Helper :: linkToDocs ( 'admin-dir_permissions' ))) . " \n " ;
2013-11-25 16:04:23 +04:00
exit ;
} else {
OC_Template :: printErrorPage (
2014-05-29 03:21:54 +04:00
$l -> t ( 'Cannot write into "config" directory!' ),
$l -> t ( 'This can usually be fixed by '
. '%sgiving the webserver write access to the config directory%s.' ,
array ( '<a href="' . \OC_Helper :: linkToDocs ( 'admin-dir_permissions' ) . '" target="_blank">' , '</a>' ))
2013-11-25 16:04:23 +04:00
);
}
2013-01-03 23:11:00 +04:00
}
}
2013-01-31 01:55:33 +04:00
public static function checkInstalled () {
2013-01-14 23:30:28 +04:00
// Redirect to installer if not installed
2014-11-28 20:52:09 +03:00
if ( ! \OC :: $server -> getSystemConfig () -> getValue ( 'installed' , false ) && OC :: $SUBURI != '/index.php' ) {
2014-07-25 21:39:29 +04:00
if ( OC :: $CLI ) {
throw new Exception ( 'Not installed' );
2014-07-24 15:45:06 +04:00
} else {
2014-07-25 21:39:29 +04:00
$url = 'http://' . $_SERVER [ 'SERVER_NAME' ] . OC :: $WEBROOT . '/index.php' ;
header ( 'Location: ' . $url );
2013-01-14 23:30:28 +04:00
}
exit ();
}
}
2013-01-31 01:55:33 +04:00
public static function checkSSL () {
2013-01-14 23:30:28 +04:00
// redirect to https site if configured
2014-11-28 20:52:09 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'forcessl' , false )) {
2014-11-03 12:55:52 +03:00
// Default HSTS policy
$header = 'Strict-Transport-Security: max-age=31536000' ;
// If SSL for subdomains is enabled add "; includeSubDomains" to the header
2014-12-04 18:48:07 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'forceSSLforSubdomains' , false )) {
2014-11-03 12:55:52 +03:00
$header .= '; includeSubDomains' ;
}
header ( $header );
ini_set ( 'session.cookie_secure' , 'on' );
2013-01-14 23:30:28 +04:00
if ( OC_Request :: serverProtocol () <> 'https' and ! OC :: $CLI ) {
2014-11-03 12:55:52 +03:00
$url = 'https://' . OC_Request :: serverHost () . OC_Request :: requestUri ();
2013-01-14 23:30:28 +04:00
header ( " Location: $url " );
exit ();
}
2013-02-14 22:23:29 +04:00
} else {
// Invalidate HSTS headers
if ( OC_Request :: serverProtocol () === 'https' ) {
header ( 'Strict-Transport-Security: max-age=0' );
}
2013-01-14 23:30:28 +04:00
}
}
2012-12-20 14:10:45 +04:00
2013-01-03 23:11:00 +04:00
public static function checkMaintenanceMode () {
2013-01-04 06:32:33 +04:00
// Allow ajax update script to execute without being stopped
2014-11-28 20:52:09 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'maintenance' , false ) && OC :: $SUBURI != '/core/ajax/update.php' ) {
2013-01-15 00:39:55 +04:00
// send http status 503
header ( 'HTTP/1.1 503 Service Temporarily Unavailable' );
header ( 'Status: 503 Service Temporarily Unavailable' );
header ( 'Retry-After: 120' );
// render error page
2013-10-24 19:46:52 +04:00
$tmpl = new OC_Template ( '' , 'update.user' , 'guest' );
2013-07-04 16:28:12 +04:00
OC_Util :: addscript ( 'maintenance-check' );
2013-10-24 19:46:52 +04:00
$tmpl -> printPage ();
die ();
2013-01-03 23:11:00 +04:00
}
}
2013-11-25 18:08:24 +04:00
public static function checkSingleUserMode () {
$user = OC_User :: getUserSession () -> getUser ();
$group = OC_Group :: getManager () -> get ( 'admin' );
2014-11-28 20:52:09 +03:00
if ( $user && \OC :: $server -> getSystemConfig () -> getValue ( 'singleuser' , false ) && ! $group -> inGroup ( $user )) {
2013-11-25 18:08:24 +04:00
// send http status 503
header ( 'HTTP/1.1 503 Service Temporarily Unavailable' );
header ( 'Status: 503 Service Temporarily Unavailable' );
header ( 'Retry-After: 120' );
// render error page
$tmpl = new OC_Template ( '' , 'singleuser.user' , 'guest' );
$tmpl -> printPage ();
die ();
}
}
2013-12-13 16:30:29 +04:00
/**
* check if the instance needs to preform an upgrade
*
* @ return bool
2014-08-14 14:22:34 +04:00
* @ deprecated use \OCP\Util :: needUpgrade () instead
2013-12-13 16:30:29 +04:00
*/
public static function needUpgrade () {
2014-06-10 20:01:07 +04:00
return \OCP\Util :: needUpgrade ();
2013-01-03 23:11:00 +04:00
}
2014-04-21 17:44:54 +04:00
/**
* Checks if the version requires an update and shows
* @ param bool $showTemplate Whether an update screen should get shown
* @ return bool | void
*/
2013-12-13 16:30:29 +04:00
public static function checkUpgrade ( $showTemplate = true ) {
2014-06-10 20:01:07 +04:00
if ( \OCP\Util :: needUpgrade ()) {
2014-11-28 20:52:09 +03:00
$systemConfig = \OC :: $server -> getSystemConfig ();
if ( $showTemplate && ! $systemConfig -> getValue ( 'maintenance' , false )) {
2014-05-26 20:43:26 +04:00
$version = OC_Util :: getVersion ();
2014-11-28 20:52:09 +03:00
$oldTheme = $systemConfig -> getValue ( 'theme' );
$systemConfig -> setValue ( 'theme' , '' );
2013-12-13 16:30:29 +04:00
OC_Util :: addScript ( 'config' ); // needed for web root
OC_Util :: addScript ( 'update' );
$tmpl = new OC_Template ( '' , 'update.admin' , 'guest' );
$tmpl -> assign ( 'version' , OC_Util :: getVersionString ());
2014-05-26 20:43:26 +04:00
// get third party apps
$apps = OC_App :: getEnabledApps ();
$incompatibleApps = array ();
foreach ( $apps as $appId ) {
$info = OC_App :: getAppInfo ( $appId );
if ( ! OC_App :: isAppCompatible ( $version , $info )) {
2014-05-27 17:20:33 +04:00
$incompatibleApps [] = $info ;
2014-05-26 20:43:26 +04:00
}
}
$tmpl -> assign ( 'appList' , $incompatibleApps );
$tmpl -> assign ( 'productName' , 'ownCloud' ); // for now
$tmpl -> assign ( 'oldTheme' , $oldTheme );
2013-12-13 16:30:29 +04:00
$tmpl -> printPage ();
exit ();
} else {
return true ;
}
}
return false ;
}
2013-01-31 01:55:33 +04:00
public static function initTemplateEngine () {
2013-01-14 23:30:28 +04:00
// Add the stuff we need always
2014-01-12 21:57:53 +04:00
// TODO: read from core/js/core.json
2014-11-04 14:51:29 +03:00
OC_Util :: addVendorScript ( 'jquery/jquery.min' );
OC_Util :: addVendorScript ( 'jquery/jquery-migrate.min' );
2013-01-23 14:37:28 +04:00
OC_Util :: addScript ( " jquery-ui-1.10.0.custom " );
2013-01-14 23:30:28 +04:00
OC_Util :: addScript ( " jquery-showpassword " );
2014-06-03 18:18:06 +04:00
OC_Util :: addScript ( " placeholders " );
2013-01-14 23:30:28 +04:00
OC_Util :: addScript ( " jquery-tipsy " );
2013-02-14 15:16:51 +04:00
OC_Util :: addScript ( " compatibility " );
2014-11-06 00:05:24 +03:00
OC_Util :: addVendorScript ( " underscore/underscore " );
2013-06-02 23:52:59 +04:00
OC_Util :: addScript ( " jquery.ocdialog " );
2013-01-14 23:30:28 +04:00
OC_Util :: addScript ( " oc-dialogs " );
OC_Util :: addScript ( " js " );
2014-10-17 21:47:37 +04:00
OC_Util :: addScript ( " l10n " );
2014-10-24 14:50:54 +04:00
OC_Util :: addTranslations ( " core " );
2013-08-15 01:06:43 +04:00
OC_Util :: addScript ( " octemplate " );
2013-01-14 23:30:28 +04:00
OC_Util :: addScript ( " eventsource " );
OC_Util :: addScript ( " config " );
//OC_Util::addScript( "multiselect" );
OC_Util :: addScript ( 'search' , 'result' );
2013-08-30 13:38:49 +04:00
OC_Util :: addScript ( " oc-requesttoken " );
2014-05-26 19:31:41 +04:00
OC_Util :: addScript ( " apps " );
2014-11-06 01:19:11 +03:00
OC_Util :: addVendorScript ( 'snapjs/dist/latest/snap' );
2014-11-03 13:18:52 +03:00
OC_Util :: addVendorScript ( 'moment/min/moment-with-locales' );
2013-01-14 23:30:28 +04:00
2013-09-01 20:17:14 +04:00
// avatars
2014-11-28 20:52:09 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'enable_avatars' , true ) === true ) {
2013-09-01 20:17:14 +04:00
\OC_Util :: addScript ( 'placeholder' );
2014-11-06 00:58:48 +03:00
\OC_Util :: addVendorScript ( 'blueimp-md5/js/md5' );
2013-09-01 20:17:14 +04:00
\OC_Util :: addScript ( 'jquery.avatar' );
\OC_Util :: addScript ( 'avatar' );
}
2013-08-29 16:26:11 +04:00
2013-01-14 23:30:28 +04:00
OC_Util :: addStyle ( " styles " );
2014-05-15 16:52:36 +04:00
OC_Util :: addStyle ( " header " );
2014-02-20 14:33:46 +04:00
OC_Util :: addStyle ( " mobile " );
2014-01-21 20:39:38 +04:00
OC_Util :: addStyle ( " icons " );
2014-06-03 21:07:08 +04:00
OC_Util :: addStyle ( " fonts " );
2013-08-30 13:38:49 +04:00
OC_Util :: addStyle ( " apps " );
2013-08-30 13:42:32 +04:00
OC_Util :: addStyle ( " fixes " );
2013-01-14 23:30:28 +04:00
OC_Util :: addStyle ( " multiselect " );
2013-01-23 14:37:28 +04:00
OC_Util :: addStyle ( " jquery-ui-1.10.0.custom " );
2013-01-14 23:30:28 +04:00
OC_Util :: addStyle ( " jquery-tipsy " );
2013-06-02 23:52:59 +04:00
OC_Util :: addStyle ( " jquery.ocdialog " );
2013-01-14 23:30:28 +04:00
}
2013-01-31 01:55:33 +04:00
public static function initSession () {
2013-01-14 23:30:28 +04:00
// prevents javascript from accessing php session cookies
ini_set ( 'session.cookie_httponly' , '1;' );
2013-04-06 02:16:52 +04:00
// set the cookie path to the ownCloud directory
2013-07-02 19:45:34 +04:00
$cookie_path = OC :: $WEBROOT ? : '/' ;
2013-04-18 23:11:55 +04:00
ini_set ( 'session.cookie_path' , $cookie_path );
2013-04-06 02:16:52 +04:00
2014-05-12 19:08:28 +04:00
// Let the session name be changed in the initSession Hook
$sessionName = OC_Util :: getInstanceId ();
2013-07-02 19:45:34 +04:00
try {
2014-05-12 19:08:28 +04:00
// Allow session apps to create a custom session object
$useCustomSession = false ;
2014-07-16 21:40:22 +04:00
$session = self :: $server -> getSession ();
OC_Hook :: emit ( 'OC' , 'initSession' , array ( 'session' => & $session , 'sessionName' => & $sessionName , 'useCustomSession' => & $useCustomSession ));
if ( $useCustomSession ) {
// use the session reference as the new Session
self :: $server -> setSession ( $session );
} else {
2014-05-12 19:08:28 +04:00
// set the session name to the instance id - which is unique
2014-07-16 21:40:22 +04:00
self :: $server -> setSession ( new \OC\Session\Internal ( $sessionName ));
2014-05-12 19:08:28 +04:00
}
2013-05-28 03:04:09 +04:00
// if session cant be started break with http 500 error
2013-07-02 19:45:34 +04:00
} catch ( Exception $e ) {
2013-11-05 00:55:55 +04:00
//show the user a detailed error page
OC_Response :: setStatus ( OC_Response :: STATUS_INTERNAL_SERVER_ERROR );
OC_Template :: printExceptionErrorPage ( $e );
2013-02-25 21:37:05 +04:00
}
2013-01-14 23:30:28 +04:00
2013-06-26 11:19:19 +04:00
$sessionLifeTime = self :: getSessionLifeTime ();
2013-01-14 23:30:28 +04:00
// regenerate session id periodically to avoid session fixation
2014-07-16 21:40:22 +04:00
/**
* @ var \OCP\ISession $session
*/
$session = self :: $server -> getSession ();
if ( ! $session -> exists ( 'SID_CREATED' )) {
$session -> set ( 'SID_CREATED' , time ());
} else if ( time () - $session -> get ( 'SID_CREATED' ) > $sessionLifeTime / 2 ) {
2013-01-14 23:30:28 +04:00
session_regenerate_id ( true );
2014-07-16 21:40:22 +04:00
$session -> set ( 'SID_CREATED' , time ());
2013-01-14 23:30:28 +04:00
}
// session timeout
2014-07-16 21:40:22 +04:00
if ( $session -> exists ( 'LAST_ACTIVITY' ) && ( time () - $session -> get ( 'LAST_ACTIVITY' ) > $sessionLifeTime )) {
2013-01-14 23:30:28 +04:00
if ( isset ( $_COOKIE [ session_name ()])) {
2013-04-18 23:11:55 +04:00
setcookie ( session_name (), '' , time () - 42000 , $cookie_path );
2013-01-14 23:30:28 +04:00
}
session_unset ();
session_destroy ();
session_start ();
}
2013-05-28 03:04:09 +04:00
2014-07-16 21:40:22 +04:00
$session -> set ( 'LAST_ACTIVITY' , time ());
2013-01-14 23:30:28 +04:00
}
2013-06-26 11:19:19 +04:00
/**
2014-02-06 19:30:58 +04:00
* @ return string
2013-06-26 11:19:19 +04:00
*/
private static function getSessionLifeTime () {
2014-11-19 15:06:22 +03:00
return \OC :: $server -> getConfig () -> getSystemValue ( 'session_lifetime' , 60 * 60 * 24 );
2013-06-26 11:19:19 +04:00
}
2013-01-31 01:55:33 +04:00
public static function loadAppClassPaths () {
foreach ( OC_APP :: getEnabledApps () as $app ) {
$file = OC_App :: getAppPath ( $app ) . '/appinfo/classpath.php' ;
if ( file_exists ( $file )) {
2013-01-18 00:44:40 +04:00
require_once $file ;
}
}
}
2013-01-18 00:42:33 +04:00
2013-01-31 01:55:33 +04:00
public static function init () {
2013-01-14 23:30:28 +04:00
// register autoloader
2014-10-15 15:53:19 +04:00
$loaderStart = microtime ( true );
2013-05-08 00:53:07 +04:00
require_once __DIR__ . '/autoloader.php' ;
2013-07-02 19:45:34 +04:00
self :: $loader = new \OC\Autoloader ();
2013-05-08 00:16:02 +04:00
spl_autoload_register ( array ( self :: $loader , 'load' ));
2014-10-15 15:53:19 +04:00
$loaderEnd = microtime ( true );
2013-01-14 23:30:28 +04:00
2014-10-04 00:13:55 +04:00
self :: initPaths ();
2014-07-29 05:48:17 +04:00
// setup 3rdparty autoloader
$vendorAutoLoad = OC :: $THIRDPARTYROOT . '/3rdparty/autoload.php' ;
if ( file_exists ( $vendorAutoLoad )) {
2014-11-17 15:10:15 +03:00
require_once $vendorAutoLoad ;
2014-07-29 05:48:17 +04:00
} else {
OC_Response :: setStatus ( OC_Response :: STATUS_SERVICE_UNAVAILABLE );
OC_Template :: printErrorPage ( 'Composer autoloader not found, unable to continue.' );
}
// setup the basic server
2014-11-27 16:50:14 +03:00
self :: $server = new \OC\Server ( \OC :: $WEBROOT );
2014-10-15 15:53:19 +04:00
\OC :: $server -> getEventLogger () -> log ( 'autoloader' , 'Autoloader' , $loaderStart , $loaderEnd );
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> start ( 'boot' , 'Initialize' );
2013-01-14 23:30:28 +04:00
// set some stuff
//ob_start();
error_reporting ( E_ALL | E_STRICT );
if ( defined ( 'DEBUG' ) && DEBUG ) {
ini_set ( 'display_errors' , 1 );
}
self :: $CLI = ( php_sapi_name () == 'cli' );
date_default_timezone_set ( 'UTC' );
ini_set ( 'arg_separator.output' , '&' );
//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
//try to set the maximum execution time to 60min
@ set_time_limit ( 3600 );
@ ini_set ( 'max_execution_time' , 3600 );
@ ini_set ( 'max_input_time' , 3600 );
//try to set the maximum filesize to 10G
@ ini_set ( 'upload_max_filesize' , '10G' );
@ ini_set ( 'post_max_size' , '10G' );
@ ini_set ( 'file_uploads' , '50' );
2014-07-19 04:16:28 +04:00
self :: handleAuthHeaders ();
2014-07-29 13:18:40 +04:00
self :: registerAutoloaderCache ();
2014-07-29 13:14:36 +04:00
2014-09-09 16:41:45 +04:00
// initialize intl fallback is necessary
\Patchwork\Utf8\Bootup :: initIntl ();
2014-07-29 05:48:17 +04:00
OC_Util :: isSetLocaleWorking ();
2014-09-09 16:41:45 +04:00
2013-07-22 00:40:35 +04:00
if ( ! defined ( 'PHPUNIT_RUN' )) {
2014-06-09 12:02:23 +04:00
OC\Log\ErrorHandler :: setLogger ( OC_Log :: $object );
2013-07-22 00:40:35 +04:00
if ( defined ( 'DEBUG' ) and DEBUG ) {
2014-01-31 16:27:51 +04:00
OC\Log\ErrorHandler :: register ( true );
2013-07-22 00:40:35 +04:00
set_exception_handler ( array ( 'OC_Template' , 'printExceptionErrorPage' ));
} else {
OC\Log\ErrorHandler :: register ();
}
2013-02-15 06:15:09 +04:00
}
2013-01-14 23:30:28 +04:00
// register the stream wrappers
2013-01-28 18:34:15 +04:00
stream_wrapper_register ( 'fakedir' , 'OC\Files\Stream\Dir' );
stream_wrapper_register ( 'static' , 'OC\Files\Stream\StaticStream' );
stream_wrapper_register ( 'close' , 'OC\Files\Stream\Close' );
2013-07-02 19:45:34 +04:00
stream_wrapper_register ( 'quota' , 'OC\Files\Stream\Quota' );
2013-01-28 18:35:30 +04:00
stream_wrapper_register ( 'oc' , 'OC\Files\Stream\OC' );
2013-01-14 23:30:28 +04:00
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> start ( 'init_session' , 'Initialize session' );
2014-05-12 19:08:28 +04:00
OC_App :: loadApps ( array ( 'session' ));
2014-11-26 15:16:22 +03:00
if ( ! self :: $CLI ) {
2014-07-25 21:39:29 +04:00
self :: initSession ();
2013-04-19 17:18:27 +04:00
}
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> end ( 'init_session' );
2014-10-24 14:50:54 +04:00
self :: initTemplateEngine ();
2013-05-31 19:31:52 +04:00
self :: checkConfig ();
self :: checkInstalled ();
self :: checkSSL ();
2014-05-12 17:14:01 +04:00
OC_Response :: addSecurityHeaders ();
2013-01-14 23:30:28 +04:00
2014-09-08 16:56:11 +04:00
$errors = OC_Util :: checkServer ( \OC :: $server -> getConfig ());
2013-01-14 23:30:28 +04:00
if ( count ( $errors ) > 0 ) {
2013-11-25 16:04:23 +04:00
if ( self :: $CLI ) {
foreach ( $errors as $error ) {
2013-12-13 16:30:29 +04:00
echo $error [ 'error' ] . " \n " ;
2013-11-25 16:04:23 +04:00
echo $error [ 'hint' ] . " \n \n " ;
}
} else {
2014-03-14 16:58:34 +04:00
OC_Response :: setStatus ( OC_Response :: STATUS_SERVICE_UNAVAILABLE );
2013-11-25 16:04:23 +04:00
OC_Template :: printGuestPage ( '' , 'error' , array ( 'errors' => $errors ));
}
2013-01-14 23:30:28 +04:00
exit ;
}
2013-06-26 11:19:19 +04:00
//try to set the session lifetime
$sessionLifeTime = self :: getSessionLifeTime ();
@ ini_set ( 'gc_maxlifetime' , ( string ) $sessionLifeTime );
2014-11-28 20:52:09 +03:00
$systemConfig = \OC :: $server -> getSystemConfig ();
2014-11-19 15:06:22 +03:00
2013-01-14 23:30:28 +04:00
// User and Groups
2014-11-28 20:52:09 +03:00
if ( ! $systemConfig -> getValue ( " installed " , false )) {
2014-07-16 21:40:22 +04:00
self :: $server -> getSession () -> set ( 'user_id' , '' );
2013-01-14 23:30:28 +04:00
}
OC_User :: useBackend ( new OC_User_Database ());
OC_Group :: useBackend ( new OC_Group_Database ());
2013-12-11 17:01:48 +04:00
2013-01-14 23:30:28 +04:00
//setup extra user backends
2014-09-08 14:30:04 +04:00
if ( ! self :: checkUpgrade ( false )) {
OC_User :: setupBackends ();
}
2013-01-14 23:30:28 +04:00
self :: registerCacheHooks ();
self :: registerFilesystemHooks ();
2013-05-29 14:01:43 +04:00
self :: registerPreviewHooks ();
2013-01-14 23:30:28 +04:00
self :: registerShareHooks ();
2013-07-10 20:07:43 +04:00
self :: registerLogRotate ();
2014-07-15 19:13:34 +04:00
self :: registerLocalAddressBook ();
2013-01-14 23:30:28 +04:00
//make sure temporary files are cleaned up
2014-10-22 19:36:52 +04:00
$tmpManager = \OC :: $server -> getTempManager ();
register_shutdown_function ( array ( $tmpManager , 'clean' ));
2013-01-14 23:30:28 +04:00
2014-11-28 20:52:09 +03:00
if ( $systemConfig -> getValue ( 'installed' , false ) && ! self :: checkUpgrade ( false )) {
if ( \OC :: $server -> getConfig () -> getAppValue ( 'core' , 'backgroundjobs_mode' , 'ajax' ) == 'ajax' ) {
2013-01-14 23:30:28 +04:00
OC_Util :: addScript ( 'backgroundjobs' );
}
}
2014-08-14 02:06:19 +04:00
// Check whether the sample configuration has been copied
2014-11-28 20:52:09 +03:00
if ( $systemConfig -> getValue ( 'copied_sample_config' , false )) {
2014-08-31 12:05:59 +04:00
$l = \OC :: $server -> getL10N ( 'lib' );
2014-08-14 02:06:19 +04:00
header ( 'HTTP/1.1 503 Service Temporarily Unavailable' );
header ( 'Status: 503 Service Temporarily Unavailable' );
OC_Template :: printErrorPage (
$l -> t ( 'Sample configuration detected' ),
$l -> t ( 'It has been detected that the sample configuration has been copied. This can break your installation and is unsupported. Please read the documentation before performing changes on config.php' )
);
return ;
}
2014-09-05 16:10:35 +04:00
$host = OC_Request :: insecureServerHost ();
// if the host passed in headers isn't trusted
if ( ! OC :: $CLI
// overwritehost is always trusted
&& OC_Request :: getOverwriteHost () === null
&& ! OC_Request :: isTrustedDomain ( $host )
) {
header ( 'HTTP/1.1 400 Bad Request' );
header ( 'Status: 400 Bad Request' );
2014-09-08 18:15:31 +04:00
2014-09-05 16:10:35 +04:00
$tmpl = new OCP\Template ( 'core' , 'untrustedDomain' , 'guest' );
2014-11-13 13:15:47 +03:00
$tmpl -> assign ( 'domain' , $_SERVER [ 'SERVER_NAME' ]);
2014-09-05 16:10:35 +04:00
$tmpl -> printPage ();
2014-09-08 18:15:31 +04:00
exit ();
2014-09-05 16:10:35 +04:00
}
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> end ( 'boot' );
2013-01-14 23:30:28 +04:00
}
2014-07-15 19:13:34 +04:00
private static function registerLocalAddressBook () {
self :: $server -> getContactsManager () -> register ( function () {
$userManager = \OC :: $server -> getUserManager ();
\OC :: $server -> getContactsManager () -> registerAddressBook (
new \OC\Contacts\LocalAddressBook ( $userManager ));
});
}
2013-01-14 23:30:28 +04:00
/**
* register hooks for the cache
*/
2013-01-31 01:55:33 +04:00
public static function registerCacheHooks () {
2014-11-28 20:52:09 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'installed' , false ) && ! \OCP\Util :: needUpgrade ()) { //don't try to do this before we are properly setup
2013-12-13 16:30:29 +04:00
\OCP\BackgroundJob :: registerJob ( 'OC\Cache\FileGlobalGC' );
2013-04-21 02:08:55 +04:00
2013-09-18 15:15:38 +04:00
// NOTE: This will be replaced to use OCP
$userSession = \OC_User :: getUserSession ();
2013-09-18 17:02:25 +04:00
$userSession -> listen ( 'postLogin' , '\OC\Cache\File' , 'loginListener' );
2013-04-21 02:08:55 +04:00
}
2013-01-14 23:30:28 +04:00
}
2013-07-10 20:07:43 +04:00
/**
* register hooks for the cache
*/
public static function registerLogRotate () {
2014-11-28 20:52:09 +03:00
$systemConfig = \OC :: $server -> getSystemConfig ();
if ( $systemConfig -> getValue ( 'installed' , false ) && $systemConfig -> getValue ( 'log_rotate_size' , false ) && ! \OCP\Util :: needUpgrade ()) {
2013-08-28 19:41:27 +04:00
//don't try to do this before we are properly setup
2014-05-20 19:29:59 +04:00
//use custom logfile path if defined, otherwise use default of owncloud.log in data directory
2014-11-28 20:52:09 +03:00
\OCP\BackgroundJob :: registerJob ( 'OC\Log\Rotate' , $systemConfig -> getValue ( 'logfile' , $systemConfig -> getValue ( 'datadirectory' , OC :: $SERVERROOT . '/data' ) . '/owncloud.log' ));
2013-07-10 20:07:43 +04:00
}
}
2013-01-14 23:30:28 +04:00
/**
* register hooks for the filesystem
*/
2013-01-31 01:55:33 +04:00
public static function registerFilesystemHooks () {
2013-01-14 23:30:28 +04:00
// Check for blacklisted files
2014-05-28 02:13:54 +04:00
OC_Hook :: connect ( 'OC_Filesystem' , 'write' , 'OC\Files\Filesystem' , 'isBlacklisted' );
OC_Hook :: connect ( 'OC_Filesystem' , 'rename' , 'OC\Files\Filesystem' , 'isBlacklisted' );
2013-01-14 23:30:28 +04:00
}
2013-05-29 14:01:43 +04:00
/**
* register hooks for previews
*/
public static function registerPreviewHooks () {
2013-05-29 14:33:24 +04:00
OC_Hook :: connect ( 'OC_Filesystem' , 'post_write' , 'OC\Preview' , 'post_write' );
2014-07-03 15:52:58 +04:00
OC_Hook :: connect ( 'OC_Filesystem' , 'delete' , 'OC\Preview' , 'prepare_delete_files' );
2014-03-11 17:21:27 +04:00
OC_Hook :: connect ( '\OCP\Versions' , 'preDelete' , 'OC\Preview' , 'prepare_delete' );
OC_Hook :: connect ( '\OCP\Trashbin' , 'preDelete' , 'OC\Preview' , 'prepare_delete' );
2014-07-03 15:52:58 +04:00
OC_Hook :: connect ( 'OC_Filesystem' , 'post_delete' , 'OC\Preview' , 'post_delete_files' );
2013-11-12 17:08:55 +04:00
OC_Hook :: connect ( '\OCP\Versions' , 'delete' , 'OC\Preview' , 'post_delete' );
OC_Hook :: connect ( '\OCP\Trashbin' , 'delete' , 'OC\Preview' , 'post_delete' );
2013-05-29 14:01:43 +04:00
}
2013-01-14 23:30:28 +04:00
/**
* register hooks for sharing
*/
2013-01-31 01:55:33 +04:00
public static function registerShareHooks () {
2014-11-28 20:52:09 +03:00
if ( \OC :: $server -> getSystemConfig () -> getValue ( 'installed' )) {
2014-02-18 18:07:03 +04:00
OC_Hook :: connect ( 'OC_User' , 'post_deleteUser' , 'OC\Share\Hooks' , 'post_deleteUser' );
OC_Hook :: connect ( 'OC_User' , 'post_addToGroup' , 'OC\Share\Hooks' , 'post_addToGroup' );
OC_Hook :: connect ( 'OC_User' , 'post_removeFromGroup' , 'OC\Share\Hooks' , 'post_removeFromGroup' );
OC_Hook :: connect ( 'OC_User' , 'post_deleteGroup' , 'OC\Share\Hooks' , 'post_deleteGroup' );
2013-05-17 03:20:02 +04:00
}
2013-01-14 23:30:28 +04:00
}
2014-07-29 13:18:40 +04:00
protected static function registerAutoloaderCache () {
// The class loader takes an optional low-latency cache, which MUST be
// namespaced. The instanceid is used for namespacing, but might be
// unavailable at this point. Futhermore, it might not be possible to
// generate an instanceid via \OC_Util::getInstanceId() because the
// config file may not be writable. As such, we only register a class
// loader cache if instanceid is available without trying to create one.
2014-11-28 20:52:09 +03:00
$instanceId = \OC :: $server -> getSystemConfig () -> getValue ( 'instanceid' , null );
2014-07-29 13:18:40 +04:00
if ( $instanceId ) {
try {
$memcacheFactory = new \OC\Memcache\Factory ( $instanceId );
self :: $loader -> setMemoryCache ( $memcacheFactory -> createLowLatency ( 'Autoloader' ));
} catch ( \Exception $ex ) {
}
}
}
2013-01-14 23:30:28 +04:00
/**
2014-05-19 19:50:53 +04:00
* Handle the request
2013-01-14 23:30:28 +04:00
*/
2013-01-31 01:55:33 +04:00
public static function handleRequest () {
2014-10-04 00:13:55 +04:00
\OC :: $server -> getEventLogger () -> start ( 'handle_request' , 'Handle request' );
2014-11-28 20:52:09 +03:00
$systemConfig = \OC :: $server -> getSystemConfig ();
2013-01-18 00:44:40 +04:00
// load all the classpaths from the enabled apps so they are available
// in the routing files of each app
OC :: loadAppClassPaths ();
2013-01-18 00:42:33 +04:00
2013-01-31 01:55:33 +04:00
// Check if ownCloud is installed or in maintenance (update) mode
2014-11-28 20:52:09 +03:00
if ( ! $systemConfig -> getValue ( 'installed' , false )) {
2014-10-31 13:21:00 +03:00
\OC :: $server -> getSession () -> clear ();
2014-10-27 14:51:26 +03:00
$controller = new OC\Core\Setup\Controller ( \OC :: $server -> getConfig ());
2013-09-10 22:19:42 +04:00
$controller -> run ( $_POST );
2013-01-31 01:55:33 +04:00
exit ();
}
2013-02-06 02:33:44 +04:00
2013-01-31 02:05:44 +04:00
$request = OC_Request :: getPathInfo ();
2013-12-13 16:30:29 +04:00
if ( substr ( $request , - 3 ) !== '.js' ) { // we need these files during the upgrade
2013-01-31 02:05:44 +04:00
self :: checkMaintenanceMode ();
self :: checkUpgrade ();
}
2013-01-31 01:55:33 +04:00
2013-11-25 18:08:24 +04:00
if ( ! self :: $CLI and ( ! isset ( $_GET [ " logout " ]) or ( $_GET [ " logout " ] !== 'true' ))) {
2013-02-07 20:53:38 +04:00
try {
2014-11-28 20:52:09 +03:00
if ( ! $systemConfig -> getValue ( 'maintenance' , false ) && ! \OCP\Util :: needUpgrade ()) {
2014-06-16 15:12:21 +04:00
OC_App :: loadApps ( array ( 'authentication' ));
OC_App :: loadApps ( array ( 'filesystem' , 'logging' ));
2014-06-24 19:37:58 +04:00
OC_App :: loadApps ();
2013-03-04 02:03:47 +04:00
}
2013-11-25 18:08:24 +04:00
self :: checkSingleUserMode ();
2014-08-28 19:58:23 +04:00
OC_Util :: setupFS ();
2014-03-10 17:06:47 +04:00
OC :: $server -> getRouter () -> match ( OC_Request :: getRawPathInfo ());
2013-02-07 20:53:38 +04:00
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 ;
}
2013-01-14 23:30:28 +04:00
}
2013-01-31 02:05:44 +04:00
2014-05-10 16:00:22 +04:00
// Load minimum set of apps
if ( ! self :: checkUpgrade ( false )) {
// For logged-in users: Load everything
if ( OC_User :: isLoggedIn ()) {
OC_App :: loadApps ();
} else {
// For guests: Load only authentication, filesystem and logging
2014-05-28 23:43:48 +04:00
OC_App :: loadApps ( array ( 'authentication' ));
OC_App :: loadApps ( array ( 'filesystem' , 'logging' ));
2014-05-10 16:00:22 +04:00
}
}
2013-01-25 17:57:52 +04:00
// Handle redirect URL for logged in users
if ( isset ( $_REQUEST [ 'redirect_url' ]) && OC_User :: isLoggedIn ()) {
$location = OC_Helper :: makeURLAbsolute ( urldecode ( $_REQUEST [ 'redirect_url' ]));
2013-05-28 03:04:09 +04:00
2013-04-23 01:26:40 +04:00
// Deny the redirect if the URL contains a @
// This prevents unvalidated redirects like ?redirect_url=:user@domain.com
2013-05-08 00:16:02 +04:00
if ( strpos ( $location , '@' ) === false ) {
2013-04-23 01:26:40 +04:00
header ( 'Location: ' . $location );
return ;
}
2013-01-25 17:57:52 +04:00
}
// Handle WebDAV
if ( $_SERVER [ 'REQUEST_METHOD' ] == 'PROPFIND' ) {
2013-10-24 12:34:09 +04:00
// not allowed any more to prevent people
// mounting this root directly.
// Users need to mount remote.php/webdav instead.
header ( 'HTTP/1.1 405 Method Not Allowed' );
header ( 'Status: 405 Method Not Allowed' );
2013-01-25 17:57:52 +04:00
return ;
}
2014-05-11 15:09:46 +04:00
// Redirect to index if the logout link is accessed without valid session
// this is needed to prevent "Token expired" messages while login if a session is expired
// @see https://github.com/owncloud/core/pull/8443#issuecomment-42425583
if ( isset ( $_GET [ 'logout' ]) && ! OC_User :: isLoggedIn ()) {
header ( " Location: " . OC :: $WEBROOT . ( empty ( OC :: $WEBROOT ) ? '/' : '' ));
return ;
}
2014-05-10 16:00:22 +04:00
// Someone is logged in
2013-01-14 23:30:28 +04:00
if ( OC_User :: isLoggedIn ()) {
OC_App :: loadApps ();
OC_User :: setupBackends ();
2014-08-28 18:59:56 +04:00
OC_Util :: setupFS ();
2013-01-14 23:30:28 +04:00
if ( isset ( $_GET [ " logout " ]) and ( $_GET [ " logout " ])) {
2014-05-04 15:56:21 +04:00
OC_JSON :: callCheck ();
2013-01-14 23:30:28 +04:00
if ( isset ( $_COOKIE [ 'oc_token' ])) {
2014-11-28 20:52:09 +03:00
\OC :: $server -> getConfig () -> deleteUserValue ( OC_User :: getUser (), 'login_token' , $_COOKIE [ 'oc_token' ]);
2013-01-14 23:30:28 +04:00
}
OC_User :: logout ();
2013-06-25 12:45:37 +04:00
// redirect to webroot and add slash if webroot is empty
header ( " Location: " . OC :: $WEBROOT . ( empty ( OC :: $WEBROOT ) ? '/' : '' ));
2013-01-14 23:30:28 +04:00
} else {
2014-05-10 16:00:22 +04:00
// Redirect to default application
OC_Util :: redirectToDefaultPage ();
2013-01-14 23:30:28 +04:00
}
2014-05-10 16:00:22 +04:00
} else {
// Not handled and not logged in
self :: handleLogin ();
2013-01-14 23:30:28 +04:00
}
}
2014-07-19 04:16:28 +04:00
protected static function handleAuthHeaders () {
//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' ];
}
// Extract PHP_AUTH_USER/PHP_AUTH_PW from other headers if necessary.
$vars = array (
'HTTP_AUTHORIZATION' , // apache+php-cgi work around
'REDIRECT_HTTP_AUTHORIZATION' , // apache+php-cgi alternative
);
foreach ( $vars as $var ) {
if ( isset ( $_SERVER [ $var ]) && preg_match ( '/Basic\s+(.*)$/i' , $_SERVER [ $var ], $matches )) {
list ( $name , $password ) = explode ( ':' , base64_decode ( $matches [ 1 ]), 2 );
2014-07-19 12:17:24 +04:00
$_SERVER [ 'PHP_AUTH_USER' ] = $name ;
$_SERVER [ 'PHP_AUTH_PW' ] = $password ;
2014-07-19 04:16:28 +04:00
break ;
}
}
}
2013-01-31 01:55:33 +04:00
protected static function handleLogin () {
2013-01-14 23:30:28 +04:00
OC_App :: loadApps ( array ( 'prelogin' ));
$error = array ();
2013-10-01 15:25:58 +04:00
2013-10-02 02:55:35 +04:00
// auth possible via apache module?
if ( OC :: tryApacheAuth ()) {
$error [] = 'apacheauthfailed' ;
2013-12-13 16:30:29 +04:00
} // remember was checked after last login
2013-10-01 15:25:58 +04:00
elseif ( OC :: tryRememberLogin ()) {
2013-01-14 23:30:28 +04:00
$error [] = 'invalidcookie' ;
2014-09-18 18:02:18 +04:00
} // logon via web form
elseif ( OC :: tryFormLogin ()) {
2013-01-14 23:30:28 +04:00
$error [] = 'invalidpassword' ;
}
2013-05-31 02:53:57 +04:00
2013-01-14 23:30:28 +04:00
OC_Util :: displayLoginPage ( array_unique ( $error ));
}
2014-04-21 17:44:54 +04:00
/**
* Remove outdated and therefore invalid tokens for a user
* @ param string $user
*/
2013-01-31 01:55:33 +04:00
protected static function cleanupLoginTokens ( $user ) {
2014-11-19 15:06:22 +03:00
$config = \OC :: $server -> getConfig ();
$cutoff = time () - $config -> getSystemValue ( 'remember_login_cookie_lifetime' , 60 * 60 * 24 * 15 );
$tokens = $config -> getUserKeys ( $user , 'login_token' );
2013-01-14 23:30:28 +04:00
foreach ( $tokens as $token ) {
2014-11-19 15:06:22 +03:00
$time = $config -> getUserValue ( $user , 'login_token' , $token );
2013-01-14 23:30:28 +04:00
if ( $time < $cutoff ) {
2014-11-19 15:06:22 +03:00
$config -> deleteUserValue ( $user , 'login_token' , $token );
2013-01-14 23:30:28 +04:00
}
}
}
2014-04-21 17:44:54 +04:00
/**
* Try to login a user via HTTP authentication
* @ return bool | void
*/
2013-10-01 15:25:58 +04:00
protected static function tryApacheAuth () {
2013-10-02 02:55:35 +04:00
$return = OC_User :: handleApacheAuth ();
// if return is true we are logged in -> redirect to the default page
if ( $return === true ) {
$_REQUEST [ 'redirect_url' ] = \OC_Request :: requestUri ();
OC_Util :: redirectToDefaultPage ();
exit ;
}
// in case $return is null apache based auth is not enabled
return is_null ( $return ) ? false : true ;
2013-10-01 15:25:58 +04:00
}
2014-04-21 17:44:54 +04:00
/**
* Try to login a user using the remember me cookie .
* @ return bool Whether the provided cookie was valid
*/
2013-01-31 01:55:33 +04:00
protected static function tryRememberLogin () {
2013-01-14 23:30:28 +04:00
if ( ! isset ( $_COOKIE [ " oc_remember_login " ])
|| ! isset ( $_COOKIE [ " oc_token " ])
|| ! isset ( $_COOKIE [ " oc_username " ])
|| ! $_COOKIE [ " oc_remember_login " ]
2013-09-24 20:01:34 +04:00
|| ! OC_Util :: rememberLoginAllowed ()
2013-01-31 01:55:33 +04:00
) {
2013-01-14 23:30:28 +04:00
return false ;
}
2014-02-06 14:34:27 +04:00
2013-01-14 23:30:28 +04:00
if ( defined ( " DEBUG " ) && DEBUG ) {
OC_Log :: write ( 'core' , 'Trying to login from cookie' , OC_Log :: DEBUG );
}
2014-05-21 20:03:37 +04:00
if ( OC_User :: userExists ( $_COOKIE [ 'oc_username' ])) {
2013-01-14 23:30:28 +04:00
self :: cleanupLoginTokens ( $_COOKIE [ 'oc_username' ]);
2014-05-24 12:24:42 +04:00
// verify whether the supplied "remember me" token was valid
2014-05-21 20:03:37 +04:00
$granted = OC_User :: loginWithCookie (
$_COOKIE [ 'oc_username' ], $_COOKIE [ 'oc_token' ]);
if ( $granted === true ) {
2013-01-14 23:30:28 +04:00
OC_Util :: redirectToDefaultPage ();
// doesn't return
}
2014-05-21 20:03:37 +04:00
OC_Log :: write ( 'core' , 'Authentication cookie rejected for user ' .
$_COOKIE [ 'oc_username' ], OC_Log :: WARN );
2013-01-14 23:30:28 +04:00
// if you reach this point you have changed your password
// or you are an attacker
// we can not delete tokens here because users may reach
// this point multiple times after a password change
}
2014-05-21 20:03:37 +04:00
2013-01-14 23:30:28 +04:00
OC_User :: unsetMagicInCookie ();
return true ;
}
2014-04-21 17:44:54 +04:00
/**
2014-09-22 16:01:45 +04:00
* Tries to login a user using the form based authentication
2014-04-21 17:44:54 +04:00
* @ return bool | void
*/
2013-01-31 01:55:33 +04:00
protected static function tryFormLogin () {
2013-01-14 23:30:28 +04:00
if ( ! isset ( $_POST [ " user " ]) || ! isset ( $_POST [ 'password' ])) {
return false ;
2013-01-04 23:16:59 +04:00
}
2013-01-14 23:30:28 +04:00
2014-09-22 17:36:39 +04:00
if ( ! OC_Util :: isCallRegistered ()) {
return false ;
}
2013-01-14 23:30:28 +04:00
OC_App :: loadApps ();
//setup extra user backends
OC_User :: setupBackends ();
if ( OC_User :: login ( $_POST [ " user " ], $_POST [ " password " ])) {
2014-09-22 16:01:45 +04:00
$userId = OC_User :: getUser ();
2013-01-14 23:30:28 +04:00
// setting up the time zone
if ( isset ( $_POST [ 'timezone-offset' ])) {
2014-07-16 21:40:22 +04:00
self :: $server -> getSession () -> set ( 'timezone' , $_POST [ 'timezone-offset' ]);
2014-09-22 16:01:45 +04:00
self :: $server -> getConfig () -> setUserValue ( $userId , 'core' , 'timezone' , $_POST [ 'timezone' ]);
2013-01-14 23:30:28 +04:00
}
2014-09-22 16:01:45 +04:00
self :: cleanupLoginTokens ( $userId );
2013-01-14 23:30:28 +04:00
if ( ! empty ( $_POST [ " remember_login " ])) {
if ( defined ( " DEBUG " ) && DEBUG ) {
2014-09-22 16:01:45 +04:00
self :: $server -> getLogger () -> debug ( 'Setting remember login to cookie' , array ( 'app' => 'core' ));
2013-01-14 23:30:28 +04:00
}
2014-09-03 19:46:48 +04:00
$token = \OC :: $server -> getSecureRandom () -> getMediumStrengthGenerator () -> generate ( 32 );
2014-09-22 16:01:45 +04:00
self :: $server -> getConfig () -> setUserValue ( $userId , 'login_token' , $token , time ());
OC_User :: setMagicInCookie ( $userId , $token );
2013-01-14 23:30:28 +04:00
} else {
OC_User :: unsetMagicInCookie ();
}
OC_Util :: redirectToDefaultPage ();
exit ();
}
return true ;
}
2011-03-03 00:18:22 +03:00
}
2010-03-10 15:03:40 +03:00
2012-12-20 14:10:45 +04:00
if ( ! function_exists ( 'get_temp_dir' )) {
2014-04-21 17:44:54 +04:00
/**
* Get the temporary dir to store uploaded data
* @ return null | string Path to the temporary directory or null
*/
2013-01-31 01:55:33 +04:00
function get_temp_dir () {
2013-01-14 23:30:28 +04:00
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 ;
$temp = tempnam ( __FILE__ , '' );
if ( file_exists ( $temp )) {
unlink ( $temp );
return dirname ( $temp );
}
if ( $temp = sys_get_temp_dir ()) return $temp ;
return null ;
}
2011-07-29 23:03:53 +04:00
}
2011-11-13 19:16:21 +04:00
OC :: init ();