fix(deps): update module github.com/getsentry/sentry-go to v0.42.0
This MR contains the following updates:
| Package | Change | Age | Confidence |
|---|---|---|---|
| github.com/getsentry/sentry-go |
v0.13.0 → v0.42.0
|
View the Renovate pipeline for this MR
Release Notes
getsentry/sentry-go (github.com/getsentry/sentry-go)
v0.42.0: 0.42.0
Breaking Changes 🛠️
- refactor Telemetry Processor to use TelemetryItem instead of ItemConvertible by @giortzisg in #1180
- remove ToEnvelopeItem from single log items
- rename TelemetryBuffer to Telemetry Processor to adhere to spec
- remove unsed ToEnvelopeItem(dsn) from Event.
New Features ✨
- Add metric support by @aldy505 in #1151
- support for three metric methods (counter, gauge, distribution)
- custom metric units
- unexport batchlogger
Internal Changes 🔧
Release
- Fix changelog-preview permissions by @BYK in #1181
- Switch from action-prepare-release to Craft by @BYK in #1167
Other
- (repo) Add Claude Code settings with basic permissions by @philipphofmann in #1175
- Update release and changelog-preview workflows by @giortzisg in #1177
- Bump echo to 4.10.1 by @giortzisg in #1174
v0.41.0: 0.41.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.41.0.
Features
- Add HTTP client integration for distributed tracing via
sentryhttpclientpackage (#876)- Provides an
http.RoundTripperimplementation that automatically creates spans for outgoing HTTP requests - Supports trace propagation targets configuration via
WithTracePropagationTargetsoption - Example usage:
import sentryhttpclient "github.com/getsentry/sentry-go/httpclient" roundTripper := sentryhttpclient.NewSentryRoundTripper(nil) client := &http.Client{ Transport: roundTripper, }
- Provides an
- Add
ClientOptions.PropagateTraceparentoption to control W3Ctraceparentheader propagation in outgoing HTTP requests (#1161) - Add
SpanIDfield to structured logs (#1169)
v0.40.0: 0.40.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.40.0.
Bug Fixes
- Disable
DisableTelemetryBufferflag and noop Telemetry Buffer, to prevent a panic at runtime (#1149).
v0.39.0: 0.39.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.39.0.
Features
- Drop events from the telemetry buffer when rate-limited or transport is full, allowing the buffer queue to empty itself under load (#1138).
Bug Fixes
- Fix scheduler's
hasWork()method to check if buffers are ready to flush. The previous implementation was causing CPU spikes (#1143).
v0.38.0: 0.38.0
Breaking Changes
Features
-
Introduce a new async envelope transport and telemetry buffer to prioritize and batch events (#1094, #1093, #1107).
- Advantages:
- Prioritized, per-category buffers (errors, transactions, logs, check-ins) reduce starvation and improve resilience under load
- Batching for high-volume logs (up to 100 items or 5s) cuts network overhead
- Bounded memory with eviction policies
- Improved flush behavior with context-aware flushing
- Advantages:
-
Add
ClientOptions.DisableTelemetryBufferto opt out and fall back to the legacy transport layer (HTTPTransport/HTTPSyncTransport).err := sentry.Init(sentry.ClientOptions{ Dsn: "__DSN__", DisableTelemetryBuffer: true, // fallback to legacy transport })
Notes
- If a custom
Transportis provided, the SDK automatically disables the telemetry buffer and uses the legacy transport for compatibility.
v0.37.0: 0.37.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.37.0.
Breaking Changes
- Behavioral change for the
TraceIgnoreStatusCodesoption. The option now defaults to ignoring 404 status codes (#1122).
Features
- Add
sentry.originattribute to structured logs to identify log origin forslogandlogrusintegrations (auto.log.slog,auto.log.logrus) (#1121).
Bug Fixes
- Fix
slogevent handler to use the initial context, ensuring events use the correct hub/span when the emission context lacks one (#1133). - Improve exception chain processing by checking pointer values when tracking visited errors, avoiding instability for certain wrapped errors (#1132).
Misc
- Bump
golang.org/x/netto v0.38.0 (#1126).
v0.36.2: 0.36.2
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.36.2.
Bug Fixes
- Fix context propagation for logs to ensure logger instances correctly inherit span and hub information from their creation context (#1118)
- Logs now properly propagate trace context from the logger's original context, even when emitted in a different context
- The logger will first check the emission context, then fall back to its creation context, and finally to the current hub
v0.36.1: 0.36.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.36.1.
Bug Fixes
- Prevent panic when converting error chains containing non-comparable error types by using a safe fallback for visited detection in exception conversion (#1113)
v0.36.0: 0.36.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.36.0.
Breaking Changes
-
Behavioral change for the
MaxBreadcrumbsclient option. Removed the hard limit of 100 breadcrumbs, allowing users to set a larger limit and also changed the default limit from 30 to 100 (#1106)) -
The changes to error handling (#1075) will affect issue grouping. It is expected that any wrapped and complex errors will be grouped under a new issue group.
Features
-
Add support for improved issue grouping with enhanced error chain handling (#1075)
The SDK now provides better handling of complex error scenarios, particularly when dealing with multiple related errors or error chains. This feature automatically detects and properly structures errors created with Go's
errors.Join()function and other multi-error patterns.// Multiple errors are now properly grouped and displayed in Sentry err1 := errors.New("err1") err2 := errors.New("err2") combinedErr := errors.Join(err1, err2) // When captured, these will be shown as related exceptions in Sentry sentry.CaptureException(combinedErr) -
Add
TraceIgnoreStatusCodesoption to allow filtering of HTTP transactions based on status codes (#1089)- Configure which HTTP status codes should not be traced by providing single codes or ranges
- Example:
TraceIgnoreStatusCodes: [][]int{{404}, {500, 599}}ignores 404 and server errors 500-599
Bug Fixes
- Fix logs being incorrectly filtered by
BeforeSendcallback (#1109)- Logs now bypass the
processEventmethod and are sent directly to the transport - This ensures logs are only filtered by
BeforeSendLog, not by the error/messageBeforeSendcallback
- Logs now bypass the
Misc
- Add support for Go 1.25 and drop support for Go 1.22 (#1103)
v0.35.3: 0.35.3
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.35.3.
Bug Fixes
- Add missing rate limit categories (#1082)
v0.35.2: 0.35.2
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.35.2.
Bug Fixes
- Fix OpenTelemetry spans being created as transactions instead of child spans (#1073)
Misc
- Add
MockTransportto test clients for improved testing (#1071)
v0.35.1: 0.35.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.35.1.
Bug Fixes
- Fix race conditions when accessing the scope during logging operations (#1050)
- Fix nil pointer dereference with malformed URLs when tracing is enabled in
fasthttpandfiberintegrations (#1055)
Misc
- Bump
github.com/gofiber/fiber/v2from 2.52.5 to 2.52.9 in/fiber(#1067)
v0.35.0: 0.35.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.35.0.
Breaking Changes
- Changes to the logging API (#1046)
The logging API now supports a fluent interface for structured logging with attributes:
// usage before
logger := sentry.NewLogger(ctx)
// attributes weren't being set permanently
logger.SetAttributes(
attribute.String("version", "1.0.0"),
)
logger.Infof(ctx, "Message with parameters %d and %d", 1, 2)
// new behavior
ctx := context.Background()
logger := sentry.NewLogger(ctx)
// Set permanent attributes on the logger
logger.SetAttributes(
attribute.String("version", "1.0.0"),
)
// Chain attributes on individual log entries
logger.Info().
String("key.string", "value").
Int("key.int", 42).
Bool("key.bool", true).
Emitf("Message with parameters %d and %d", 1, 2)
Bug Fixes
- Correctly serialize
FailureIssueThresholdandRecoveryThresholdonto check-in payloads (#1060)
v0.34.1: 0.34.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.34.1.
Bug Fixes
- Allow flush to be used multiple times without issues, particularly for the batch logger (#1051)
- Fix race condition in
Scope.GetSpan()method by adding proper mutex locking (#1044) - Guard transport on
Close()to prevent panic when called multiple times (#1044)
v0.34.0: 0.34.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.34.0.
Breaking Changes
- Logrus structured logging support replaces the
sentrylogrus.Hooksignature from a*Hookto an interface.
var hook *sentrylogrus.Hook
hook = sentrylogrus.New(
// ... your setup
)
// should change the definition to
var hook sentrylogrus.Hook
hook = sentrylogrus.New(
// ... your setup
)
Features
ctx := context.Background()
handler := sentryslog.Option{
EventLevel: []slog.Level{slog.LevelError, sentryslog.LevelFatal}, // Only Error and Fatal as events
LogLevel: []slog.Level{slog.LevelWarn, slog.LevelInfo}, // Only Warn and Info as logs
}.NewSentryHandler(ctx)
logger := slog.New(handler)
logger.Info("hello"))
logHook, _ := sentrylogrus.NewLogHook(
[]logrus.Level{logrus.InfoLevel, logrus.WarnLevel},
sentry.ClientOptions{
Dsn: "your-dsn",
EnableLogs: true, // Required for log entries
})
defer logHook.Flush(5 * time.Secod)
logrus.RegisterExitHandler(func() {
logHook.Flush(5 * time.Second)
})
logger := logrus.New()
logger.AddHook(logHook)
logger.Infof("hello")
- Add support for flushing events with context using
FlushWithContext(). (#935)
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
if !sentry.FlushWithContext(ctx) {
// Handle timeout or cancellation
}
- Add support for custom fingerprints in slog integration. (#1039)
Deprecations
- Slog structured logging support replaces
Leveloption withEventLevelandLogLeveloptions, for specifying fine-grained levels for capturing events and logs.
handler := sentryslog.Option{
EventLevel: []slog.Level{slog.LevelWarn, slog.LevelError, sentryslog.LevelFatal},
LogLevel: []slog.Level{slog.LevelDebug, slog.LevelInfo, slog.LevelWarn, slog.LevelError, sentryslog.LevelFatal},
}.NewSentryHandler(ctx)
- Logrus structured logging support replaces
NewandNewFromClientfunctions toNewEventHook,NewEventHookFromClient, to match the newly addedNewLogHookfunctions, and specify the hook type being created each time.
logHook, err := sentrylogrus.NewLogHook(
[]logrus.Level{logrus.InfoLevel},
sentry.ClientOptions{})
eventHook, err := sentrylogrus.NewEventHook([]logrus.Level{
logrus.ErrorLevel,
logrus.FatalLevel,
logrus.PanicLevel,
}, sentry.ClientOptions{})
Bug Fixes
- Fix issue where
ContinueTrace()would panic whensentry-traceheader does not exist. (#1026) - Fix incorrect log level signature in structured logging. (#1034)
- Remove
sentry.originattribute from Sentry logger to prevent confusion in spans. (#1038) - Don't gate user information behind
SendDefaultPIIflag for logs. (#1032)
Misc
- Add more sensitive HTTP headers to the default list of headers that are scrubbed by default. (#1008)
v0.33.0: 0.33.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.33.0.
Breaking Changes
- Rename the internal
LoggertoDebugLogger. This feature was only used when you setDebug: Truein yoursentry.Init()call. If you haven't used the Logger directly, no changes are necessary. (#1012)
Features
-
Add support for Structured Logging. (#1010)
logger := sentry.NewLogger(ctx) logger.Info(ctx, "Hello, Logs!")You can learn more about Sentry Logs on our docs and the examples.
-
Add new attributes APIs, which are currently only exposed on logs. (#1007)
Bug Fixes
- Do not push a new scope on
StartSpan. (#1013) - Fix an issue where the propagated smapling decision wasn't used. (#995)
- [Otel] Prefer
httpRouteoverhttpTargetfor span descriptions. (#1002)
Misc
- Update
github.com/stretchr/testifyto v1.8.4. (#988)
v0.32.0: 0.32.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.32.0.
Breaking Changes
- Bump the minimum Go version to 1.22. The supported versions are 1.22, 1.23 and 1.24. (#967)
- Setting any values on
span.Extrahas no effect anymore. UseSetData(name string, value interface{})instead. (#864)
Features
- Add a
MockTransportandMockScope. (#972)
Bug Fixes
- Fix writing
*http.Requestin the Logrus JSONFormatter. (#955)
Misc
- Transaction
dataattributes are now seralized as trace context data attributes, allowing you to query these attributes in the Trace Explorer.
v0.31.1: 0.31.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.31.1.
Bug Fixes
- Correct wrong module name for
sentry-go/logrus(#950)
v0.31.0: 0.31.0
Breaking Changes
-
Remove support for metrics. Read more about the end of the Metrics beta here. (#914)
-
Remove support for profiling. (#915)
-
Remove
Segmentfield from theUserstruct. This field is no longer used in the Sentry product. (#928) -
Every integration is now a separate module, reducing the binary size and number of dependencies. Once you update
sentry-goto latest version, you'll need togo getthe integration you want to use. For example, if you want to use theechointegration, you'll need to rungo get github.com/getsentry/sentry-go/echo(#919).
Features
-
Add the ability to override
hubincontextfor integrations that use custom context. (#931) -
Add
HubProviderHook forsentrylogrus, enabling dynamic Sentry hub allocation for each log entry or goroutine. (#936)
This change enhances compatibility with Sentry's recommendation of using separate hubs per goroutine. To ensure a separate Sentry hub for each goroutine, configure the HubProvider like this:
hook, err := sentrylogrus.New(nil, sentry.ClientOptions{})
if err != nil {
log.Fatalf("Failed to initialize Sentry hook: %v", err)
}
// Set a custom HubProvider to generate a new hub for each goroutine or log entry
hook.SetHubProvider(func() *sentry.Hub {
client, _ := sentry.NewClient(sentry.ClientOptions{})
return sentry.NewHub(client, sentry.NewScope())
})
logrus.AddHook(hook)
Bug Fixes
- Add support for closing worker goroutines started by the
HTTPTranportto prevent goroutine leaks. (#894)
client, _ := sentry.NewClient()
defer client.Close()
Worker can be also closed by calling Close() method on the HTTPTransport instance. Close should be called after Flush and before terminating the program otherwise some events may be lost.
transport := sentry.NewHTTPTransport()
defer transport.Close()
Misc
- Bump gin-gonic/gin to v1.9.1. (#946)
v0.30.0: 0.30.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.30.0.
Features
- Add
sentryzerologintegration (#857) - Add
sentryslogintegration (#865) - Always set Mechanism Type to generic (#896)
Bug Fixes
- Prevent panic in
fasthttpandfiberintegration in case a malformed URL has to be parsed (#912)
Misc
Drop support for Go 1.18, 1.19 and 1.20. The currently supported Go versions are the last 3 stable releases: 1.23, 1.22 and 1.21.
v0.29.1: 0.29.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.29.1.
Bug Fixes
- Correlate errors to the current trace (#886)
- Set the trace context when the transaction finishes (#888)
Misc
- Update the
sentrynegroniintegration to use the latest (v3.1.1) version of Negroni (#885)
v0.29.0: 0.29.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.29.0.
Breaking Changes
- Remove the
sentrymartiniintegration (#861) - The
WrapResponseWriterhas been moved from thesentryhttppackage to theinternal/httputilspackage. If you've imported it previosuly, you'll need to copy the implementation in your project. (#871)
Features
-
Add new convenience methods to continue a trace and propagate tracing headers for error-only use cases. (#862)
If you are not using one of our integrations, you can manually continue an incoming trace by using
sentry.ContinueTrace()by providing thesentry-traceandbaggageheader received from a downstream SDK.hub := sentry.CurrentHub() sentry.ContinueTrace(hub, r.Header.Get(sentry.SentryTraceHeader), r.Header.Get(sentry.SentryBaggageHeader)),You can use
hub.GetTraceparent()andhub.GetBaggage()to fetch the necessary header values for outgoing HTTP requests.hub := sentry.GetHubFromContext(ctx) req, _ := http.NewRequest("GET", "http://localhost:3000", nil) req.Header.Add(sentry.SentryTraceHeader, hub.GetTraceparent()) req.Header.Add(sentry.SentryBaggageHeader, hub.GetBaggage())
Bug Fixes
- Initialize
HTTPTransport.limitifnil(#844) - Fix
sentry.StartTransaction()returning a transaction with an outdated context on existing transactions (#854) - Treat
Proxy-Authorizationas a sensitive header (#859) - Add support for the
http.Hijackerinterface to thesentrynegronipackage (#871) - Go version >= 1.23: Use value from
http.Request.Patternfor HTTP transaction names when usingsentryhttp&sentrynegroni(#875) - Go version >= 1.21: Fix closure functions name grouping (#877)
Misc
- Collect
spanorigins (#849)
v0.28.1: 0.28.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.28.1.
Bug Fixes
- Implement
http.ResponseWriterto hook into various parts of the response process (#837)
v0.28.0: 0.28.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.28.0.
Features
- Add a
Fiberperformance tracing & error reporting integration (#795) - Add performance tracing to the
Echointegration (#722) - Add performance tracing to the
FastHTTPintegration (#732) - Add performance tracing to the
Irisintegration (#809) - Add performance tracing to the
Negroniintegration (#808) - Add
FailureIssueThreshold&RecoveryThresholdtoMonitorConfig(#775) - Use
errors.Unwrap()to create exception groups (#792) - Add support for matching on strings for
ClientOptions.IgnoreErrors&ClientOptions.IgnoreTransactions(#819) - Add
http.request.methodattribute for performance span data (#786) - Accept
interface{}for span data values (#784)
Fixes
- Fix missing stack trace for parsing error in
logrusentry(#689)
v0.27.0: 0.27.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.27.0.
Breaking Changes
-
Exception.ThreadIdis now typed asuint64. It was wrongly typed asstringbefore. (#770)
Misc
- Export
Event.Attachments(#771)
v0.26.0: 0.26.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.26.0.
Breaking Changes
As previously announced, this release removes some methods from the SDK.
-
sentry.TransactionName()usesentry.WithTransactionName()instead. -
sentry.OpName()usesentry.WithOpName()instead. -
sentry.TransctionSource()usesentry.WithTransactionSource()instead. -
sentry.SpanSampled()usesentry.WithSpanSampled()instead.
Features
-
Add
WithDescriptionspan option (#751)span := sentry.StartSpan(ctx, "http.client", WithDescription("GET /api/users")) -
Add support for package name parsing in Go 1.20 and higher (#730)
Bug Fixes
- Apply
ClientOptions.SampleRateonly to errors & messages (#754) - Check if git is available before executing any git commands (#737)
v0.25.0: 0.25.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.25.0.
Breaking Changes
As previously announced, this release removes two global constants from the SDK.
-
sentry.Versionwas removed. Usesentry.SDKVersioninstead (#727) -
sentry.SDKIdentifierwas removed. UseClient.GetSDKIdentifier()instead (#727)
Features
- Add
ClientOptions.IgnoreTransactions, which allows you to ignore specific transactions based on their name (#717) - Add
ClientOptions.Tags, which allows you to set global tags that are applied to all events. You can also define tags by settingSENTRY_TAGS_environment variables (#718)
Bug fixes
- Fix an issue in the profiler that would cause an infinite loop if the duration of a transaction is longer than 30 seconds (#724)
Misc
-
dsn.RequestHeaders()is not to be removed, though it is still considered deprecated and should only be used when using a custom transport that sends events to the/storeendpoint (#720)
v0.24.1: 0.24.1
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.24.1.
Bug fixes
- Prevent a panic in
sentryotel.flushSpanProcessor()((#711)) - Prevent a panic when setting the SDK identifier (#715)
v0.24.0: 0.24.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.24.0.
Deprecations
-
sentry.Versionto be removed in 0.25.0. Usesentry.SDKVersioninstead. -
sentry.SDKIdentifierto be removed in 0.25.0. UseClient.GetSDKIdentifier()instead. -
dsn.RequestHeaders()to be removed after 0.25.0, but no earlier than December 1, 2023. Requests to the/envelopeendpoint are authenticated using the DSN in the envelope header.
Features
- Run a single instance of the profiler instead of multiple ones for each Go routine (#655)
- Use the route path as the transaction names when using the Gin integration (#675)
- Set the SDK name accordingly when a framework integration is used (#694)
- Read release information (VCS revision) from
debug.ReadBuildInfo(#704)
Bug fixes
- [otel] Fix incorrect usage of
attributes.Value.AsString(#684) - Fix trace function name parsing in profiler on go1.21+ (#695)
Misc
v0.23.0: 0.23.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.23.0.
Features
-
Initial support for Cron Monitoring (#661)
This is how the basic usage of the feature looks like:
// 🟡 Notify Sentry your job is running: checkinId := sentry.CaptureCheckIn( &sentry.CheckIn{ MonitorSlug: "<monitor-slug>", Status: sentry.CheckInStatusInProgress, }, nil, ) // Execute your scheduled task here... // 🟢 Notify Sentry your job has completed successfully: sentry.CaptureCheckIn( &sentry.CheckIn{ ID: *checkinId, MonitorSlug: "<monitor-slug>", Status: sentry.CheckInStatusOK, }, nil, )A full example of using Crons Monitoring is available here.
More documentation on configuring and using Crons can be found here.
-
Add support for Event Attachments (#670)
It's now possible to add file/binary payloads to Sentry events:
sentry.ConfigureScope(func(scope *sentry.Scope) { scope.AddAttachment(&Attachment{ Filename: "report.html", ContentType: "text/html", Payload: []byte("<h1>Look, HTML</h1>"), }) })The attachment will then be accessible on the Issue Details page.
-
Add sampling decision to trace envelope header (#666)
-
Expose SpanFromContext function (#672)
Bug fixes
- Make
Span.Finisha no-op when the span is already finished (#660)
v0.22.0: 0.22.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.22.0.
This release contains initial profiling support, as well as a few bug fixes and improvements.
Features
-
Initial (alpha) support for profiling (#626)
Profiling is disabled by default. To enable it, configure both
TracesSampleRateandProfilesSampleRatewhen initializing the SDK:err := sentry.Init(sentry.ClientOptions{ Dsn: "__DSN__", EnableTracing: true, TracesSampleRate: 1.0, // The sampling rate for profiling is relative to TracesSampleRate. In this case, we'll capture profiles for 100% of transactions. ProfilesSampleRate: 1.0, })More documentation on profiling and current limitations can be found here.
-
Add transactions/tracing support go the Gin integration (#644)
Bug fixes
- Always set a valid source on transactions (#637)
- Clone scope.Context in more places to avoid panics on concurrent reads and writes (#638)
- Fixes #570
- Fix frames recognized as not being in-app still showing as in-app (#647)
v0.21.0: 0.21.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.21.0.
Note: this release includes one breaking change and some deprecations, which are listed below.
Breaking Changes
This change does not apply if you use https://sentry.io
- Remove support for the
/storeendpoint (#631)- This change requires a self-hosted version of Sentry 20.6.0 or higher. If you are using a version of self-hosted Sentry (aka on-premise) older than 20.6.0, then you will need to upgrade your instance.
Features
- Rename four span option functions (#611, #624)
-
TransctionSource->WithTransactionSource -
SpanSampled->WithSpanSampled -
OpName->WithOpName -
TransactionName->WithTransactionName - Old functions
TransctionSource,SpanSampled,OpName, andTransactionNameare still available but are now deprecated and will be removed in a future release.
-
- Make
client.EventFromMessageandclient.EventFromExceptionmethods public (#607) - Add
client.SetExceptionmethod (#607)- This allows to set or add errors to an existing
Event.
- This allows to set or add errors to an existing
Bug Fixes
- Protect from panics while doing concurrent reads/writes to Span data fields (#609)
- [otel] Improve detection of Sentry-related spans (#632, #636)
- Fixes cases when HTTP spans containing requests to Sentry were captured by Sentry (#627)
Misc
- Drop testing in (legacy) GOPATH mode (#618)
- Remove outdated documentation from https://pkg.go.dev/github.com/getsentry/sentry-go (#623)
v0.20.0: 0.20.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.20.0.
Note: this release has some breaking changes, which are listed below.
Breaking Changes
-
Remove the following methods:
Scope.SetTransaction(),Scope.Transaction()(#605)Span.Name should be used instead to access the transaction's name.
For example, the following
TracesSamplerfunction should be now written as follows:Before:
TracesSampler: func(ctx sentry.SamplingContext) float64 { hub := sentry.GetHubFromContext(ctx.Span.Context()) if hub.Scope().Transaction() == "GET /health" { return 0 } return 1 },After:
TracesSampler: func(ctx sentry.SamplingContext) float64 { if ctx.Span.Name == "GET /health" { return 0 } return 1 },
Features
- Add
Span.SetContext()method (#599)- It is recommended to use it instead of
hub.Scope().SetContextwhen setting or updating context on transactions.
- It is recommended to use it instead of
- Add
DebugMetainterface toEventand extendFramestructure with more fields (#606)- More about DebugMeta interface here.
Bug Fixes
- [otel] Fix missing OpenTelemetry context on some events (#599, #605)
- Fixes (#596).
- [otel] Better handling for HTTP span attributes (#610)
Misc
- Bump minimum versions:
github.com/kataras/iris/v12to 12.2.0,github.com/labstack/echo/v4to v4.10.0 (#595) - Bump
google.golang.org/protobufminimum required version to 1.29.1 (#604)- This fixes a potential denial of service issue (CVE-2023-24535).
- Exclude the
otelmodule when building in GOPATH mode (#615)
v0.19.0: 0.19.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.19.0.
Features
Bug Fixes
- [otel] Use the correct "trace" context when sending a Sentry error (#580)
Misc
- Drop support for Go 1.17, add support for Go 1.20 (#563)
- According to our policy, we're officially supporting the last three minor releases of Go.
- Switch repository license to MIT (#583)
- More about Sentry licensing here.
- Bump
golang.org/x/textminimum required version to 0.3.8 (#586)- This fixes CVE-2022-32149 vulnerability.
v0.18.0: 0.18.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.18.0. This release contains initial support for OpenTelemetry and various other bug fixes and improvements.
Note: This is the last release supporting Go 1.17.
Features
-
Initial support for OpenTelemetry. You can now send all your OpenTelemetry spans to Sentry.
Install the
otelmodulego get github.com/getsentry/sentry-go \ github.com/getsentry/sentry-go/otelConfigure the Sentry and OpenTelemetry SDKs
import ( "go.opentelemetry.io/otel" sdktrace "go.opentelemetry.io/otel/sdk/trace" "github.com/getsentry/sentry-go" "github.com/getsentry/sentry-go/otel" // ... ) // Initlaize the Sentry SDK sentry.Init(sentry.ClientOptions{ Dsn: "__DSN__", EnableTracing: true, TracesSampleRate: 1.0, }) // Set up the Sentry span processor tp := sdktrace.NewTracerProvider( sdktrace.WithSpanProcessor(sentryotel.NewSentrySpanProcessor()), // ... ) otel.SetTracerProvider(tp) // Set up the Sentry propagator otel.SetTextMapPropagator(sentryotel.NewSentryPropagator())You can read more about using OpenTelemetry with Sentry in our docs.
Bug Fixes
- Do not freeze the Dynamic Sampling Context when no Sentry values are present in the baggage header (#532)
- Create a frozen Dynamic Sampling Context when calling
span.ToBaggage()(#566) - Fix baggage parsing and encoding in vendored otel package (#568)
Misc
- Add
Span.SetDynamicSamplingContext()(#539) - Add various getters for
Dsn(#540) - Add
SpanOption::SpanSampled(#546) - Add
Span.SetData()(#542) - Add
Span.IsTransaction()(#543) - Add
Span.GetTransaction()method (#558)
v0.17.0: 0.17.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.17.0.
This release contains a new BeforeSendTransaction hook option and corrects two regressions introduced in 0.16.0.
Features
- Add
BeforeSendTransactionhook toClientOptions(#517)- Here's an example of how BeforeSendTransaction can be used to modify or drop transaction events.
Bug Fixes
- Do not crash in Span.Finish() when the Client is empty (#520)
- Fixes #518
- Attach non-PII/non-sensitive request headers to events when
ClientOptions.SendDefaultPiiis set tofalse(#524)- Fixes #523
Misc
- Clarify how to handle logrus.Fatalf events (#501)
- Rename the
examplesdirectory to_examples(#521)- This removes an indirect dependency to
github.com/golang-jwt/jwt
- This removes an indirect dependency to
v0.16.0: 0.16.0
The Sentry SDK team is happy to announce the immediate availability of Sentry Go SDK v0.16.0.
Due to ongoing work towards a stable API for v1.0.0, we sadly had to include two breaking changes in this release.
Breaking Changes
- Add
EnableTracing, a boolean option flag to enable performance monitoring (falseby default).-
If you're using
TracesSampleRateorTracesSampler, this option is required to enable performance monitoring.sentry.Init(sentry.ClientOptions{ EnableTracing: true, TracesSampleRate: 1.0, })
-
- Unify TracesSampler #498
-
TracesSamplerwas changed to a callback that must return afloat64between0.0and1.0.For example, you can apply a sample rate of
1.0(100%) to all/apitransactions, and a sample rate of0.5(50%) to all other transactions. You can read more about this in our SDK docs.sentry.Init(sentry.ClientOptions{ TracesSampler: sentry.TracesSampler(func(ctx sentry.SamplingContext) float64 { hub := sentry.GetHubFromContext(ctx.Span.Context()) name := hub.Scope().Transaction() if strings.HasPrefix(name, "GET /api") { return 1.0 } return 0.5 }), }
-
Features
- Send errors logged with Logrus to Sentry.
- Have a look at our logrus examples on how to use the integration.
- Add support for Dynamic Sampling #491
- You can read more about Dynamic Sampling in our product docs.
- Add detailed logging about the reason transactions are being dropped.
- You can enable SDK logging via
sentry.ClientOptions.Debug: true.
- You can enable SDK logging via
Bug Fixes
v0.15.0: 0.15.0
- fix: Scope values should not override Event values (#446)
- feat: Make maximum amount of spans configurable (#460)
- feat: Add a method to start a transaction (#482)
- feat: Extend User interface by adding Data, Name and Segment (#483)
- feat: Add ClientOptions.SendDefaultPII (#485)
v0.14.0: 0.14.0
- feat: Add function to continue from trace string (#434)
- feat: Add
max-depthoptions (#428) -
[breaking] ref: Use a
Contexttype mapping to amap[string]interface{}for all event contexts (#444) -
[breaking] ref: Replace deprecated
ioutilpkg withos&io(#454) - ref: Optimize
stacktrace.gofrom size and speed (#467) - ci: Test against
go1.19andgo1.18, dropgo1.16andgo1.15support (#432, #477) - deps: Dependency update to fix CVEs (#462, #464, #477)
NOTE: This version drops support for Go 1.16 and Go 1.15. The currently supported Go versions are the last 3 stable releases: 1.19, 1.18 and 1.17.
Configuration
- If you want to rebase/retry this MR, check this box
This MR has been generated by Renovate Bot.