diff options
author | Morris Jobke <hey@morrisjobke.de> | 2015-10-02 16:59:43 +0200 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2015-10-06 10:20:53 +0200 |
commit | b05422544d6dbd6247e17dd7ec2582279b2558ca (patch) | |
tree | 60e944619b540913545500462195a7424227f309 /lib | |
parent | da640adf688baef651df08a81e04089553a6c3a0 (diff) | |
download | nextcloud-server-b05422544d6dbd6247e17dd7ec2582279b2558ca.tar.gz nextcloud-server-b05422544d6dbd6247e17dd7ec2582279b2558ca.zip |
Fixes last causes for WSOD
* print plain text if rendering of exception/error page is not possible
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/template.php | 55 |
1 files changed, 39 insertions, 16 deletions
diff --git a/lib/private/template.php b/lib/private/template.php index 0300e43edea..c6ae99f99b7 100644 --- a/lib/private/template.php +++ b/lib/private/template.php @@ -300,10 +300,20 @@ class OC_Template extends \OC\Template\Base { * @param string $hint An optional hint message - needs to be properly escaped */ public static function printErrorPage( $error_msg, $hint = '' ) { - $content = new \OC_Template( '', 'error', 'error', false ); - $errors = array(array('error' => $error_msg, 'hint' => $hint)); - $content->assign( 'errors', $errors ); - $content->printPage(); + try { + $content = new \OC_Template( '', 'error', 'error', false ); + $errors = array(array('error' => $error_msg, 'hint' => $hint)); + $content->assign( 'errors', $errors ); + $content->printPage(); + } catch (\Exception $e) { + $logger = \OC::$server->getLogger(); + $logger->error("$error_msg $hint", ['app' => 'core']); + $logger->logException($e, ['app' => 'core']); + + header($_SERVER['SERVER_PROTOCOL'] . ' 500 Internal Server Error'); + header('Content-Type: text/plain; charset=utf-8'); + print("$error_msg $hint"); + } die(); } @@ -312,18 +322,31 @@ class OC_Template extends \OC\Template\Base { * @param Exception $exception */ public static function printExceptionErrorPage($exception) { - $request = \OC::$server->getRequest(); - $content = new \OC_Template('', 'exception', 'error', false); - $content->assign('errorClass', get_class($exception)); - $content->assign('errorMsg', $exception->getMessage()); - $content->assign('errorCode', $exception->getCode()); - $content->assign('file', $exception->getFile()); - $content->assign('line', $exception->getLine()); - $content->assign('trace', $exception->getTraceAsString()); - $content->assign('debugMode', \OC::$server->getSystemConfig()->getValue('debug', false)); - $content->assign('remoteAddr', $request->getRemoteAddress()); - $content->assign('requestID', $request->getId()); - $content->printPage(); + try { + $request = \OC::$server->getRequest(); + $content = new \OC_Template('', 'exception', 'error', false); + $content->assign('errorClass', get_class($exception)); + $content->assign('errorMsg', $exception->getMessage()); + $content->assign('errorCode', $exception->getCode()); + $content->assign('file', $exception->getFile()); + $content->assign('line', $exception->getLine()); + $content->assign('trace', $exception->getTraceAsString()); + $content->assign('debugMode', \OC::$server->getSystemConfig()->getValue('debug', false)); + $content->assign('remoteAddr', $request->getRemoteAddress()); + $content->assign('requestID', $request->getId()); + $content->printPage(); + } catch (\Exception $e) { + $logger = \OC::$server->getLogger(); + $logger->logException($exception, ['app' => 'core']); + $logger->logException($e, ['app' => 'core']); + + header($_SERVER['SERVER_PROTOCOL'] . ' 500 Internal Server Error'); + header('Content-Type: text/plain; charset=utf-8'); + print("Internal Server Error\n\n"); + print("The server encountered an internal error and was unable to complete your request.\n"); + print("Please contact the server administrator if this error reappears multiple times, please include the technical details below in your report.\n"); + print("More details can be found in the server log.\n"); + } die(); } |