diff options
author | Louis <louis@chmn.me> | 2024-09-05 22:44:37 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-05 22:44:37 +0200 |
commit | 8f28394a067b98094afbfdec118c56d5e0ddad88 (patch) | |
tree | 9ecf5581c037f79158b3500b6ced76bc5110d41c /core | |
parent | dd9f7493426973571c960de968cb68662ff12233 (diff) | |
parent | 987840592e6d15c8031f06691d28576757dd2fb1 (diff) | |
download | nextcloud-server-8f28394a067b98094afbfdec118c56d5e0ddad88.tar.gz nextcloud-server-8f28394a067b98094afbfdec118c56d5e0ddad88.zip |
Merge pull request #47786 from nextcloud/backport/47770/stable29
[stable29] fix(dav): Always respond custom error page on exceptions
Diffstat (limited to 'core')
-rw-r--r-- | core/templates/xml_exception.php | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/core/templates/xml_exception.php b/core/templates/xml_exception.php new file mode 100644 index 00000000000..d7fb276a730 --- /dev/null +++ b/core/templates/xml_exception.php @@ -0,0 +1,47 @@ +<?php +/** + * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors + * SPDX-FileCopyrightText: 2012-2015 ownCloud, Inc. + * SPDX-License-Identifier: AGPL-3.0-only + */ + +function print_exception(Throwable $e, \OCP\IL10N $l): void { + p($e->getTraceAsString()); + + if ($e->getPrevious() !== null) { + print_unescaped('<s:previous-exception>'); + print_exception($e->getPrevious(), $l); + print_unescaped('</s:previous-exception>'); + } +} + +?> +<?xml version="1.0" encoding="utf-8"?> +<d:error xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns"> + <s:exception><?php p($l->t('Internal Server Error')) ?></s:exception> + <s:message> + <?php p($l->t('The server was unable to complete your request.')) ?> + <?php p($l->t('If this happens again, please send the technical details below to the server administrator.')) ?> + <?php p($l->t('More details can be found in the server log.')) ?> + <?php if (isset($_['serverLogsDocumentation']) && $_['serverLogsDocumentation'] !== ''): ?> + <?php p($l->t('For more details see the documentation ↗.'))?>: <?php print_unescaped($_['serverLogsDocumentation']) ?> + <?php endif; ?> + </s:message> + + <s:technical-details> + <s:remote-address><?php p($_['remoteAddr']) ?></s:remote-address> + <s:request-id><?php p($_['requestID']) ?></s:request-id> + + <?php if (isset($_['debugMode']) && $_['debugMode'] === true): ?> + <s:type><?php p($_['errorClass']) ?></s:type> + <s:code><?php p($_['errorCode']) ?></s:code> + <s:message><?php p($_['errorMsg']) ?></s:message> + <s:file><?php p($_['file']) ?></s:file> + <s:line><?php p($_['line']) ?></s:line> + + <s:stacktrace> + <?php print_exception($_['exception'], $l); ?> + </s:stacktrace> + <?php endif; ?> + </s:technical-details> +</d:error> |