Pre-filter some events before sending to sentry (#654)
* Filter some errors from Sentry and add exception message to fingerprint * Move to new Sentry SDKpull/6/head
parent
7d4d923903
commit
c7a772363f
@ -1,73 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using SharpRaven.Data;
|
|
||||||
|
|
||||||
namespace NzbDrone.Common.Instrumentation.Sentry
|
|
||||||
{
|
|
||||||
public class LidarrJsonPacketFactory : IJsonPacketFactory
|
|
||||||
{
|
|
||||||
private readonly SentryPacketCleanser _cleanser;
|
|
||||||
|
|
||||||
public LidarrJsonPacketFactory()
|
|
||||||
{
|
|
||||||
_cleanser = new SentryPacketCleanser();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static string ShortenPath(string path)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (string.IsNullOrWhiteSpace(path))
|
|
||||||
{
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
var index = path.IndexOf("\\src\\", StringComparison.Ordinal);
|
|
||||||
|
|
||||||
if (index <= 0)
|
|
||||||
{
|
|
||||||
return path;
|
|
||||||
}
|
|
||||||
|
|
||||||
return path.Substring(index + "\\src".Length);
|
|
||||||
}
|
|
||||||
|
|
||||||
public JsonPacket Create(string project, SentryEvent @event)
|
|
||||||
{
|
|
||||||
var packet = new LidarrSentryPacket(project, @event);
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
foreach (var exception in packet.Exceptions)
|
|
||||||
{
|
|
||||||
foreach (var frame in exception.Stacktrace.Frames)
|
|
||||||
{
|
|
||||||
frame.Filename = ShortenPath(frame.Filename);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
_cleanser.CleansePacket(packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
catch (Exception)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return packet;
|
|
||||||
}
|
|
||||||
|
|
||||||
[Obsolete]
|
|
||||||
public JsonPacket Create(string project, SentryMessage message, ErrorLevel level = ErrorLevel.Info, IDictionary<string, string> tags = null,
|
|
||||||
string[] fingerprint = null, object extra = null)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
[Obsolete]
|
|
||||||
public JsonPacket Create(string project, Exception exception, SentryMessage message = null, ErrorLevel level = ErrorLevel.Error,
|
|
||||||
IDictionary<string, string> tags = null, string[] fingerprint = null, object extra = null)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,12 +0,0 @@
|
|||||||
using SharpRaven.Data;
|
|
||||||
|
|
||||||
namespace NzbDrone.Common.Instrumentation.Sentry
|
|
||||||
{
|
|
||||||
public class MachineNameUserFactory : ISentryUserFactory
|
|
||||||
{
|
|
||||||
public SentryUser Create()
|
|
||||||
{
|
|
||||||
return new SentryUser(HashUtil.AnonymousToken());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,80 @@
|
|||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using NzbDrone.Common.EnvironmentInfo;
|
||||||
|
using Sentry;
|
||||||
|
using Sentry.Protocol;
|
||||||
|
|
||||||
|
namespace NzbDrone.Common.Instrumentation.Sentry
|
||||||
|
{
|
||||||
|
public static class SentryCleanser
|
||||||
|
{
|
||||||
|
public static SentryEvent CleanseEvent(SentryEvent sentryEvent)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
sentryEvent.Message = CleanseLogMessage.Cleanse(sentryEvent.Message);
|
||||||
|
|
||||||
|
if (sentryEvent.Fingerprint != null)
|
||||||
|
{
|
||||||
|
var fingerprint = sentryEvent.Fingerprint.Select(x => CleanseLogMessage.Cleanse(x)).ToList();
|
||||||
|
sentryEvent.SetFingerprint(fingerprint);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sentryEvent.Extra != null)
|
||||||
|
{
|
||||||
|
var extras = sentryEvent.Extra.ToDictionary(x => x.Key, y => (object)CleanseLogMessage.Cleanse((string)y.Value));
|
||||||
|
sentryEvent.SetExtras(extras);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (var exception in sentryEvent.SentryExceptions)
|
||||||
|
{
|
||||||
|
foreach (var frame in exception.Stacktrace.Frames)
|
||||||
|
{
|
||||||
|
frame.FileName = ShortenPath(frame.FileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return sentryEvent;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Breadcrumb CleanseBreadcrumb(Breadcrumb b)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var message = CleanseLogMessage.Cleanse(b.Message);
|
||||||
|
var data = b.Data?.ToDictionary(x => x.Key, y => CleanseLogMessage.Cleanse(y.Value));
|
||||||
|
return new Breadcrumb(message, b.Type, data, b.Category, b.Level);
|
||||||
|
}
|
||||||
|
catch(Exception)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return b;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static string ShortenPath(string path)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (string.IsNullOrWhiteSpace(path))
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var rootDir = OsInfo.IsWindows ? "\\src\\" : "/src/";
|
||||||
|
var index = path.IndexOf(rootDir, StringComparison.Ordinal);
|
||||||
|
|
||||||
|
if (index <= 0)
|
||||||
|
{
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
|
return path.Substring(index + rootDir.Length - 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,31 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
|
||||||
using Newtonsoft.Json.Linq;
|
|
||||||
|
|
||||||
namespace NzbDrone.Common.Instrumentation.Sentry
|
|
||||||
{
|
|
||||||
public class SentryPacketCleanser
|
|
||||||
{
|
|
||||||
public void CleansePacket(LidarrSentryPacket packet)
|
|
||||||
{
|
|
||||||
packet.Message = CleanseLogMessage.Cleanse(packet.Message);
|
|
||||||
|
|
||||||
if (packet.Fingerprint != null)
|
|
||||||
{
|
|
||||||
for (var i = 0; i < packet.Fingerprint.Length; i++)
|
|
||||||
{
|
|
||||||
packet.Fingerprint[i] = CleanseLogMessage.Cleanse(packet.Fingerprint[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (packet.Extra != null)
|
|
||||||
{
|
|
||||||
var target = JObject.FromObject(packet.Extra);
|
|
||||||
new CleansingJsonVisitor().Visit(target);
|
|
||||||
packet.Extra = target;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in new issue