aboutsummaryrefslogtreecommitdiff
path: root/Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2017-02-24 15:21:11 -0500
committerGitHub <noreply@github.com>2017-02-24 15:21:11 -0500
commitcd6b7f3bdc5bcbc6c68131cc40b71b68ac1b73a6 (patch)
tree48b8f6d94e3f762a486aa1c4fa6937cf23c18dee /Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs
parentc07e774ca9c0f234ec6899e17fc70301d1990290 (diff)
parent66a844e6399f1d79be8e10ea098ba6768e0d123b (diff)
Merge pull request #2489 from MediaBrowser/beta
Beta
Diffstat (limited to 'Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs')
-rw-r--r--Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs43
1 files changed, 43 insertions, 0 deletions
diff --git a/Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs b/Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs
new file mode 100644
index 000000000..5183f3a0b
--- /dev/null
+++ b/Emby.Server.Implementations/Logging/UnhandledExceptionWriter.cs
@@ -0,0 +1,43 @@
+using MediaBrowser.Common.Configuration;
+using MediaBrowser.Model.Logging;
+using System;
+using System.IO;
+using MediaBrowser.Model.IO;
+
+namespace Emby.Server.Implementations.Logging
+{
+ public class UnhandledExceptionWriter
+ {
+ private readonly IApplicationPaths _appPaths;
+ private readonly ILogger _logger;
+ private readonly ILogManager _logManager;
+ private readonly IFileSystem _fileSystem;
+ private readonly IConsoleLogger _console;
+
+ public UnhandledExceptionWriter(IApplicationPaths appPaths, ILogger logger, ILogManager logManager, IFileSystem fileSystem, IConsoleLogger console)
+ {
+ _appPaths = appPaths;
+ _logger = logger;
+ _logManager = logManager;
+ _fileSystem = fileSystem;
+ _console = console;
+ }
+
+ public void Log(Exception ex)
+ {
+ _logger.ErrorException("UnhandledException", ex);
+ _logManager.Flush();
+
+ var path = Path.Combine(_appPaths.LogDirectoryPath, "unhandled_" + Guid.NewGuid() + ".txt");
+ _fileSystem.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());
+
+ _fileSystem.WriteAllText(path, builder.ToString());
+ }
+ }
+}