summaryrefslogtreecommitdiffstats
path: root/index.php
blob: 1b9b4a58f7f9fdbfbbe316f223437db328f93d86 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?php

/**
* ownCloud
*
* @author Frank Karlitschek
* @copyright 2010 Frank Karlitschek karlitschek@kde.org
*
* 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/>.
*
*/

$RUNTIME_NOAPPS = true; //no apps, yet

function logException($ex) {
	$message = $ex->getMessage();
	if ($ex->getCode()) {
		$message .= ' [' . $message . ']';
	}
	\OCP\Util::writeLog('index', $message, \OCP\Util::FATAL);
	if (defined('DEBUG') and DEBUG) {
		// also log stack trace
		$stack = explode('#', $ex->getTraceAsString());
		// first element is empty
		array_shift($stack);
		foreach ($stack as $s) {
			\OCP\Util::writeLog('index', $s, \OCP\Util::FATAL);
		}

		// include cause
		$l = OC_L10N::get('lib');
		while (method_exists($ex, 'getPrevious') && $ex = $ex->getPrevious()) {
			$message .= ' - '.$l->t('Caused by:').' ';
			$message .= $ex->getMessage();
			if ($ex->getCode()) {
				$message .= '['.$ex->getCode().'] ';
			}
			\OCP\Util::writeLog('index', $message, \OCP\Util::FATAL);
		}
	}
}

try {
	
	require_once 'lib/base.php';

	OC::handleRequest();

} catch (Exception $ex) {
	logException($ex);

	//show the user a detailed error page
	OC_Response::setStatus(OC_Response::STATUS_INTERNAL_SERVER_ERROR);
	OC_Template::printExceptionErrorPage($ex);
}