summaryrefslogtreecommitdiffstats
path: root/lib/private/log.php
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2015-09-24 17:01:31 +0200
committerMorris Jobke <hey@morrisjobke.de>2015-09-24 20:01:30 +0200
commitdb8e7ce8b95c882c876f932296f25ec08883a1d3 (patch)
tree807952698b4a0704172285f989563ac572df2762 /lib/private/log.php
parent846b8268672df2c626616fec5f71e15570005e84 (diff)
downloadnextcloud-server-db8e7ce8b95c882c876f932296f25ec08883a1d3.tar.gz
nextcloud-server-db8e7ce8b95c882c876f932296f25ec08883a1d3.zip
Remove passwords from logged exception stack traces
* fixed #16318 * create logException in ILogger * add unit tests
Diffstat (limited to 'lib/private/log.php')
-rw-r--r--lib/private/log.php21
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/private/log.php b/lib/private/log.php
index 3c0e7b45d1b..1b26ece7624 100644
--- a/lib/private/log.php
+++ b/lib/private/log.php
@@ -241,4 +241,25 @@ class Log implements ILogger {
call_user_func(array($logger, 'write'), $app, $message, $level);
}
}
+
+ /**
+ * Logs an exception very detailed
+ *
+ * @param \Exception $exception
+ * @param array $context
+ * @return void
+ * @since 8.2.0
+ */
+ public function logException(\Exception $exception, array $context = array()) {
+ $exception = array(
+ 'Exception' => get_class($exception),
+ 'Message' => $exception->getMessage(),
+ 'Code' => $exception->getCode(),
+ 'Trace' => $exception->getTraceAsString(),
+ 'File' => $exception->getFile(),
+ 'Line' => $exception->getLine(),
+ );
+ $exception['Trace'] = preg_replace('!(login|checkPassword)\(.*\)!', '$1(*** username and password replaced ***)', $exception['Trace']);
+ $this->error('Exception: ' . json_encode($exception), $context);
+ }
}