diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2014-11-23 17:36:40 -0500 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2014-11-23 17:36:40 -0500 |
| commit | 1923de72bf3c502ba9b942ef6caa5f73a33f43d6 (patch) | |
| tree | 9104da63d3f657a3cd8cb7beae70ab6ab614caf9 /MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs | |
| parent | 70c5b341dbaf274ebc57743fe51b9b8e7d73d441 (diff) | |
consolidate exception logging
Diffstat (limited to 'MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs')
| -rw-r--r-- | MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs b/MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs new file mode 100644 index 000000000..96c24eaab --- /dev/null +++ b/MediaBrowser.Server.Startup.Common/UnhandledExceptionWriter.cs @@ -0,0 +1,39 @@ +using MediaBrowser.Common.Configuration; +using MediaBrowser.Common.Implementations.Logging; +using MediaBrowser.Model.Logging; +using System; +using System.IO; + +namespace MediaBrowser.Server.Startup.Common +{ + 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()); + } + } +} |
