aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Core/UnhandledExceptionWriter.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Emby.Server.Core/UnhandledExceptionWriter.cs')
-rw-r--r--Emby.Server.Core/UnhandledExceptionWriter.cs38
1 files changed, 38 insertions, 0 deletions
diff --git a/Emby.Server.Core/UnhandledExceptionWriter.cs b/Emby.Server.Core/UnhandledExceptionWriter.cs
new file mode 100644
index 000000000..5147be9e7
--- /dev/null
+++ b/Emby.Server.Core/UnhandledExceptionWriter.cs
@@ -0,0 +1,38 @@
+using MediaBrowser.Common.Configuration;
+using MediaBrowser.Model.Logging;
+using System;
+using System.IO;
+
+namespace Emby.Server.Core
+{
+ public class UnhandledExceptionWriter
+ {
+ private readonly IApplicationPaths _appPaths;
+ private readonly ILogger _logger;
+ private readonly ILogManager _logManager;
+
+ public UnhandledExceptionWriter(IApplicationPaths appPaths, ILogger logger, ILogManager logManager)
+ {
+ _appPaths = appPaths;
+ _logger = logger;
+ _logManager = logManager;
+ }
+
+ public void Log(Exception ex)
+ {
+ _logger.ErrorException("UnhandledException", ex);
+ _logManager.Flush();
+
+ var path = Path.Combine(_appPaths.LogDirectoryPath, "unhandled_" + Guid.NewGuid() + ".txt");
+ Directory.CreateDirectory(Path.GetDirectoryName(path));
+
+ var builder = LogHelper.GetLogMessage(ex);
+
+ // Write to console just in case file logging fails
+ Console.WriteLine("UnhandledException");
+ Console.WriteLine(builder.ToString());
+
+ File.WriteAllText(path, builder.ToString());
+ }
+ }
+}