Sentry 0.0.1-preview3

Prefix Reserved
This is a prerelease version of Sentry.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Sentry --version 0.0.1-preview3                
NuGet\Install-Package Sentry -Version 0.0.1-preview3                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Sentry" Version="0.0.1-preview3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Sentry --version 0.0.1-preview3                
#r "nuget: Sentry, 0.0.1-preview3"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Sentry as a Cake Addin
#addin nuget:?package=Sentry&version=0.0.1-preview3&prerelease

// Install Sentry as a Cake Tool
#tool nuget:?package=Sentry&version=0.0.1-preview3&prerelease                

Below you will find a basic introduction to the SDK and its API.

For more details, please: refer to the SDK documentation

Main features

  • Automatic Captures global unhandled exceptions (AppDomain)
  • Scope management
  • Duplicate events automatically dropped
  • Events from the same exception automatically dropped
  • Web proxy support
  • DSN discovered via environment variable
  • Release (version) reported automatically
  • CLS Compliant
  • Strong named
  • SourceLink (including PDB in nuget package)
  • Device OS info sent
  • Device Runtime info sent
  • Tested on Windows, Linux and macOS
  • Tested on .NET Core, .NET Framework and Mono

Basics

Initialize the SDK:

void Main() 
{
    using (SentrySdk.Init("dsn"))
    {
        // App code
    }
}

The SDK by default will watch for unhandled exceptions in your app. If the DSN is not explicitly passed by parameter to Init, the SDK will try to locate it via environment variable SENTRY_DSN.

To configure advanced settings, for example a proxy server:

void Main() 
{
    using (SentrySdk.Init(o =>
    {
        o.Dsn = new Dsn("dsn");
        o.Http(h =>
        {
            h.Proxy = new WebProxy("https://localhost:3128");
        });
    }))
    {
        // App code
    }
}

Capture an exception:

try
{
    throw null;
}
catch (Exception e)
{
    SentrySdk.CaptureException(e);
}

Capture a message:

SentrySdk.CaptureMessage("this just happened");

Internals/Testability

It's often the case we don't want to couple our code with static class like SentrySdk, especially to allow our code to be testable. If that's your case, you can use 2 abstractions:

  • ISentryClient
  • IHub

The ISentryClient is responsible to queueing the event to be sent to Sentry and abstracting away the internal transport. The IHub on the other hand, holds a client and the current scope. It in fact also implements ISentryClient and is able to dispatch calls to the right client depending on the current scope.

In order to allow different events hold different contextual data, you need to know in which scope you are in. That's the job of the Hub. It holds the scope management as well as a client.

If all you are doing is sending events, without modification/access to the current scope, then you depend on ISentryClient. If on the other hand you would like to have access to the current scope by configuring it or binding a different client to it, etc. You'd depend on IHub.

An example using IHub for testability is SentryLogger and its unit tests SentryLoggerTests.
SentryLogger depends on IHub because it does modify the scope (through AddBreadcrumb). In case it only sent events, it should instead depend on ISentryClient

Compatibility

The packages target .NET Standard 2.0. That means it is compatible with the following versions or newer:

  • .NET Framework 4.6.1
  • .NET Core 2.0
  • Mono 5.4
  • Xamarin.Android 8.0
  • Xamarin.Mac 3.8
  • Xamarin.iOS 10.14
  • Universal Windows Platform 10.0.16299

Of those, we've tested (we run our unit/integration tests) against:

  • .NET Framework 4.6.2 on Windows (AppVeyor)
  • Mono 5.12 macOS and Linux (Travis-CI)
  • .NET Core 2.0 Windows (AppVeyor), macOS and Linux (Travis-CI)
  • .NET Core 2.1 Windows (AppVeyor), macOS and Linux (Travis-CI)
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (80)

Showing the top 5 NuGet packages that depend on Sentry:

Package Downloads
Sentry.Extensions.Logging

Official Microsoft.Extensions.Logging integration for Sentry - Open-source error tracking that helps developers monitor and fix crashes in real time.

Sentry.Serilog

Official Serilog integration for Sentry - Open-source error tracking that helps developers monitor and fix crashes in real time.

Sentry.NLog

Official NLog integration for Sentry - Open-source error tracking that helps developers monitor and fix crashes in real time.

Sentry.DiagnosticSource

Official Diagnostic.Listener integration for Sentry - Open-source error tracking that helps developers monitor and fix crashes in real time. Note: This package is not needed when using Sentry with .NET Core 3 or higher.

VisioForge.DotNet.Core

VisioForge .Net products for video capture, editing and playback (Video Capture SDK, Media Player SDK, Video Edit SDK). Core package.

GitHub repositories (52)

Showing the top 5 popular GitHub repositories that depend on Sentry:

Repository Stars
files-community/Files
A modern file manager that helps users organize their files and folders.
ppy/osu
rhythm is just a *click* away!
Sonarr/Sonarr
Smart PVR for newsgroup and bittorrent users.
Radarr/Radarr
Movie organizer/manager for usenet and torrent users.
LykosAI/StabilityMatrix
Multi-Platform Package Manager for Stable Diffusion
Version Downloads Last updated
5.1.1 38,592 2/13/2025
5.1.0 98,078 2/3/2025
5.0.1 406,008 1/8/2025
5.0.0 376,707 12/19/2024
5.0.0-alpha.1 7,197 11/25/2024
5.0.0-alpha.0 153 11/24/2024
4.13.0 1,102,554 11/5/2024
4.12.2 63,021 11/2/2024
4.12.1 663,919 10/10/2024
4.12.1-segv1 820 11/1/2024
4.12.0 285,635 10/2/2024
4.11.0 510,270 9/22/2024
4.10.2 1,033,803 8/21/2024
4.10.1 172,374 8/16/2024
4.10.0 63,336 8/14/2024
4.9.0 1,199,234 7/11/2024
4.9.0-sync.collection.2 308 7/30/2024
4.9.0-sync.collection.1 118 7/30/2024
4.8.1 267,874 7/2/2024
4.8.0 224,055 6/26/2024
4.7.0 1,038,094 5/27/2024 4.7.0 is deprecated.
4.6.2 447,261 5/14/2024 4.6.2 is deprecated.
4.6.0 106,301 5/9/2024 4.6.0 is deprecated.
4.5.0 317,275 4/30/2024 4.5.0 is deprecated.
4.4.0 535,679 4/12/2024 4.4.0 is deprecated.
4.3.0 168,554 4/10/2024 4.3.0 is deprecated.
4.2.1 877,288 3/12/2024 4.2.1 is deprecated.
4.2.0 43,886 3/11/2024 4.2.0 is deprecated.
4.1.2 1,190,622 2/20/2024 4.1.2 is deprecated.
4.1.1 200,752 2/14/2024 4.1.1 is deprecated.
4.1.0 181,858 2/9/2024 4.1.0 is deprecated.
4.0.3 82,350 2/7/2024 4.0.3 is deprecated.
4.0.2 90,210 2/6/2024 4.0.2 is deprecated.
4.0.1 43,388 2/5/2024 4.0.1 is deprecated.
4.0.0 119,631 2/1/2024 4.0.0 is deprecated.
4.0.0-beta.9 1,137 1/30/2024
4.0.0-beta.8 18,332 1/11/2024
4.0.0-beta.7 7,956 1/5/2024
4.0.0-beta.6 19,775 12/13/2023
4.0.0-beta.5 2,535 12/12/2023
4.0.0-beta.4 22,095 12/5/2023
4.0.0-beta.3 595 12/2/2023
4.0.0-beta.2 4,787 11/23/2023
4.0.0-beta.1 1,052 11/19/2023
4.0.0-beta.0 619 11/17/2023
4.0.0-alpha.0 7,705 11/9/2023
3.41.4 1,224,875 1/23/2024
3.41.3 1,622,692 11/29/2023
3.41.2 345,771 11/23/2023
3.41.1 80,750 11/22/2023
3.41.0 940,535 11/8/2023
3.40.1 816,070 10/12/2023
3.40.0 143,121 10/10/2023
3.40.0-beta.0 16,032 9/21/2023
3.39.1 1,574,398 9/12/2023
3.39.0 229,106 9/7/2023
3.36.0 639,809 8/22/2023
3.35.1 259,440 8/16/2023
3.35.0 178,094 8/8/2023 3.35.0 is deprecated.
3.34.0 1,204,171 7/13/2023
3.33.1 1,364,262 6/13/2023
3.33.0 1,215,278 5/22/2023
3.32.0 27,499 5/22/2023
3.31.0 799,422 5/2/2023
3.30.0 1,204,668 4/11/2023
3.29.1 1,825,275 3/11/2023
3.29.0 251,835 3/6/2023
3.28.1 1,408,339 2/10/2023
3.28.0 78,152 2/8/2023
3.27.1 351,563 2/3/2023
3.27.0 151,005 2/1/2023
3.26.2 721,988 1/24/2023
3.26.1 288,809 1/17/2023
3.26.0 375,281 1/13/2023
3.25.0 1,224,859 12/23/2022
3.24.1 355,777 12/16/2022
3.24.0 1,773,393 11/18/2022
3.23.1 911,505 10/31/2022
3.23.0 102,578 10/27/2022
3.22.0 1,465,055 10/7/2022
3.21.0 1,765,572 9/2/2022
3.20.1 1,734,469 7/26/2022
3.19.0 966,308 6/28/2022
3.18.0 620,553 6/15/2022
3.17.1 1,463,156 5/8/2022
3.17.0 147,539 5/3/2022
3.16.0 984,630 4/7/2022
3.15.0 1,003,471 3/15/2022
3.14.1 910,936 2/18/2022
3.14.0 212,794 2/14/2022
3.13.0 1,506,164 1/11/2022
3.12.3 1,083,269 12/19/2021
3.12.2 85,845 12/15/2021
3.12.1 375,783 12/6/2021
3.12.0 299,663 11/23/2021
3.12.0-alpha.1 6,092 11/7/2021
3.11.1 692,743 11/5/2021
3.11.0 162,392 11/2/2021
3.10.0 665,305 10/15/2021
3.9.4 1,018,330 9/29/2021
3.9.3 173,686 9/21/2021
3.9.2 241,651 9/10/2021
3.9.1 14,935 9/9/2021
3.9.0 308,958 8/27/2021
3.8.3 842,687 7/25/2021
3.8.2 142,337 7/17/2021
3.8.1 27,902 7/15/2021
3.8.0 123,930 7/14/2021
3.7.0 138,384 7/10/2021
3.6.1 183,561 7/2/2021
3.6.0 242,144 6/23/2021
3.6.0-alpha.2 660 6/18/2021
3.6.0-alpha.1 1,269 6/11/2021
3.5.0 482,612 6/7/2021 3.5.0 is deprecated because it has critical bugs.
3.4.0 152,273 5/31/2021 3.4.0 is deprecated because it has critical bugs.
3.4.0-beta.0 340 5/27/2021 3.4.0-beta.0 is deprecated because it has critical bugs.
3.3.5-beta.0 2,577 5/13/2021
3.3.4 773,997 4/26/2021
3.3.3 9,193 4/23/2021
3.3.2 24,809 4/23/2021
3.3.1 578,746 4/5/2021
3.3.0 34,330 4/3/2021
3.2.0 133,153 3/26/2021
3.1.0 389,733 3/10/2021
3.0.8 71,506 3/4/2021
3.0.7 243,425 2/20/2021
3.0.6 104,125 2/14/2021
3.0.5 71,667 2/9/2021
3.0.4 31,982 2/8/2021
3.0.3 80,202 2/3/2021
3.0.2 23,567 2/3/2021
3.0.1 145,164 1/29/2021
3.0.0 43,021 1/28/2021
3.0.0-beta.0 7,002 1/20/2021
3.0.0-alpha.11 504 1/15/2021
3.0.0-alpha.10 64,123 1/10/2021
3.0.0-alpha.9 2,277 12/29/2020
3.0.0-alpha.8 4,557 12/25/2020
3.0.0-alpha.7 3,006 12/16/2020
3.0.0-alpha.6 3,813 11/30/2020
3.0.0-alpha.5 3,304 11/21/2020
3.0.0-alpha.4 2,468 11/2/2020
3.0.0-alpha.3 1,826 10/29/2020
3.0.0-alpha.2 864 10/21/2020
3.0.0-alpha.1 6,141 10/16/2020
3.0.0-alpha.0 2,131 9/25/2020
2.2.0-alpha 2,696 9/19/2020
2.1.8 2,078,587 11/21/2020
2.1.6 2,133,344 8/20/2020
2.1.5 613,388 7/27/2020
2.1.5-beta 4,258 6/30/2020
2.1.4 634,769 6/25/2020
2.1.3 700,339 6/5/2020
2.1.2-beta5 7,983 5/19/2020
2.1.2-beta4 4,987 5/12/2020
2.1.2-beta3 2,127 5/7/2020
2.1.2-beta2 22,200 4/16/2020
2.1.2-beta 4,413 3/31/2020
2.1.1 1,598,343 3/19/2020
2.1.0 772,715 2/24/2020
2.0.3 597,078 2/12/2020
2.0.2 36,343 2/8/2020
2.0.1 280,616 1/28/2020
2.0.0-beta8 24,250 1/15/2020
2.0.0-beta7 162,819 12/17/2019
2.0.0-beta6 103,155 10/31/2019
2.0.0-beta5 7,360 10/29/2019
2.0.0-beta4 75,947 9/4/2019
2.0.0-beta3 17,212 7/26/2019
2.0.0-beta2 6,286 6/9/2019
2.0.0-beta 3,380 6/4/2019
1.2.1-beta 2,326 5/27/2019
1.2.0 3,172,089 5/23/2019
1.1.3-beta4 2,041 5/15/2019
1.1.3-beta3 1,814 5/13/2019
1.1.3-beta2 7,990 3/28/2019
1.1.3-beta 5,482 2/11/2019
1.1.2 640,204 1/16/2019
1.1.2-beta 3,632 1/8/2019
1.1.1 24,470 1/5/2019
1.1.0 117,089 12/5/2018
1.0.1-beta5 2,765 12/5/2018
1.0.1-beta4 3,479 12/3/2018
1.0.1-beta3 18,530 11/15/2018
1.0.1-beta2 3,376 11/14/2018
1.0.1-beta 21,001 10/24/2018
1.0.0 294,619 10/2/2018
1.0.0-rc2 24,736 9/7/2018
1.0.0-rc 5,996 8/24/2018
0.0.1-preview5 7,585 8/5/2018
0.0.1-preview4 5,138 7/30/2018
0.0.1-preview3 6,718 7/17/2018
0.0.1-preview2 6,092 7/3/2018
0.0.1-preview1 2,670 6/28/2018