2011-10-17 07:09:43 +03:00
|
|
|
using System.Diagnostics;
|
2010-10-24 10:46:58 +03:00
|
|
|
using Exceptioneer.WindowsFormsClient;
|
|
|
|
using NLog;
|
|
|
|
using NLog.Targets;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Instrumentation
|
|
|
|
{
|
|
|
|
public class ExceptioneerTarget : Target
|
|
|
|
{
|
2011-07-04 08:03:05 +03:00
|
|
|
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
|
|
|
|
|
2010-10-24 10:46:58 +03:00
|
|
|
protected override void Write(LogEventInfo logEvent)
|
|
|
|
{
|
2011-10-17 07:09:43 +03:00
|
|
|
if (logEvent == null || logEvent.Exception == null) return;
|
|
|
|
if (Debugger.IsAttached || Process.GetCurrentProcess().ProcessName.Contains("JetBrains")) return;
|
2011-10-17 22:23:34 +03:00
|
|
|
|
2011-10-17 07:09:43 +03:00
|
|
|
Logger.Trace("Sending Exception to Exceptioneer. {0}", Process.GetCurrentProcess().ProcessName);
|
|
|
|
|
2011-10-17 22:23:34 +03:00
|
|
|
logEvent.Exception.Data.Add("Message", logEvent.Message);
|
|
|
|
|
2011-10-17 07:09:43 +03:00
|
|
|
new Client
|
|
|
|
{
|
|
|
|
ApiKey = "43BBF60A-EB2A-4C1C-B09E-422ADF637265",
|
|
|
|
ApplicationName = "NZBDrone",
|
|
|
|
CurrentException = logEvent.Exception
|
|
|
|
}.Submit();
|
2011-07-04 08:03:05 +03:00
|
|
|
|
2010-10-24 10:46:58 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|