summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2015-10-02 16:59:43 +0200
committerMorris Jobke <hey@morrisjobke.de>2015-10-06 10:20:53 +0200
commitb05422544d6dbd6247e17dd7ec2582279b2558ca (patch)
tree60e944619b540913545500462195a7424227f309 /lib
parentda640adf688baef651df08a81e04089553a6c3a0 (diff)
downloadnextcloud-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.php55
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();
}