Migration Guide
Migrate between versions of Sentry's SDK for Dart.
API changes:
- Sentry's Dart SDK version 7.0.0 and above requires Dart 2.17.0.
- Sentry's sentry_filepackage version 7.0.0 and above requires Dart2.19.0.
- Methods that used to take a dynamic hintoptional parameter now takeHint? hintinstead.
- The following deprecated fields have been removed from the SentryDeviceclass and replaced:- screenResolutionreplaced with- screenHeightPixelsand- screenWidthPixels.
- timezonereplaced with- SentryCulture#timezone.
- languagereplaced with- SentryCulture#locale.
- themereplaced with- SentryOperatingSystem#theme.
 
- The following deprecated field has been removed from the Contexts#dart_contextdatabag and replaced:- isolatereplaced with- SentryThread#name.
 
- The following fields have been removed from the Scopeclass and replaced:- user(SentryUser? user)replaced with- setUser(SentryUser? user).
- attachementsreplaced with- attachments.
 
- Classes or methods that used to take the below optional parameters, have been moved to the SentryOptionsclass and replaced:- captureFailedRequestsreplaced with- SentryOptions#captureFailedRequests.
- sendDefaultPiireplaced with- SentryOptions#sendDefaultPii.
- maxRequestBodySizereplaced with- SentryOptions#maxRequestBodySize.
- networkTracingreplaced with- SentryOptions#tracesSampleRateor- SentryOptions#tracesSampler.
- recordBreadcrumbsreplaced with- SentryOptions#recordHttpBreadcrumbs.
 
- The following SentryMeasurementUnitsare now strongly typed:- DurationSentryMeasurementUnit
- InformationSentryMeasurementUnit
- FractionSentryMeasurementUnit
- CustomSentryMeasurementUnit
- NoneSentryMeasurementUnit
 
Behavior changes:
- Sentry's Dart SDK version 7.0.0 and above supports Dart 3.0.0.
- When an unhandled error happens and there's a running transaction, the transaction status will be set to internal_error.
- The captureFailedRequestsfeature is now enabled by default.
- The enableStructuredDataTracingfeature is now enabled by default.
- The enableUserInteractionTracingfeature is now enabled by default.
- SentryOptions#sendClientReportsis now enabled by default. To disable it, use the code snippet below:
Copied
import 'package:sentry/sentry.dart';
Future<void> main() async {
  await Sentry.init((options) => options.sendClientReports = false;
}
- The - Scope.usersetter was deprecated in favor of- Scope.setUser, and it will be removed in a future update.
- The - Scope.attachementsgetter was deprecated in favor of- attachments, and it will be removed in a future update.
- The following - Scopemethods now return- Future<void>instead of- void:- setContexts
- removeContexts
- setUser
- addBreadcrumb
- clearBreadcrumbs
- setExtra
- removeExtra
- setTag
- removeTag
 
- Starting with version 6.6.0ofsentry, Sentry's version >= v21.9.0 is required or you have to manually disable sending client reports via thesendClientReportsoption. This only applies to self-hosted Sentry. If you are using sentry.io, no action is needed.
- Sentry.currentHubwas removed. Please use the static methods on- Sentry
- SentryOptions.cacheDirSizewas renamed to- SentryOptions.maxCacheItems
- EventProcessorwas changed from a callback to an interface
- The data type from the following options was changed from inttoDuration. The old options are still present but deprecated and will be removed in a future version.- SentryOptions.autoSessionTrackingIntervalMillisto- SentryOptions.autoSessionTrackingInterval
- SentryOptions.anrTimeoutIntervalMillisto- SentryOptions.anrTimeoutInterval
 
- The beforeSendcallback now accepts async code. The method signature changed fromSentryEvent? Function(SentryEvent event, {dynamic hint});toFutureOr<SentryEvent?> Function(SentryEvent event, {dynamic hint});. While this is technically a breaking change, your code probably is still valid.
- Sentry accepts multiple exceptions and multiple threads. If you haven't set exceptions, there's no need to do anything.
- Starting with version 6.0.0of thesentry, Sentry's version >= v20.6.0 is required. This only applies to self-hosted Sentry. If you are using sentry.io, no action is needed.
- Sentry's Dart SDK version 5.0.0 and above requires Dart 1.12.0
- Fix: Prefix classes with Sentry- A couple of classes were often conflicting with user's code. As a result, this change renames the following classes:- App->- SentryApp
- Browser->- SentryBrowser
- Device->- SentryDevice
- Gpu->- SentryGpu
- Integration->- SentryIntegration
- Message->- SentryMessage
- OperatingSystem->- SentryOperatingSystem
- Orientation->- SentryOrientation
- Request->- SentryRequest
- User->- SentryUser
 
 
- A couple of classes were often conflicting with user's code. As a result, this change renames the following classes:
- Return type of Sentry.close()changed fromvoidtoFuture<void>andIntegration.close()changed fromvoidtoFutureOr<void>
Help improve this content
Our documentation is open source and available on GitHub. Your contributions are welcome, whether fixing a typo (drat!) or suggesting an update ("yeah, this would be better").
Our documentation is open source and available on GitHub. Your contributions are welcome, whether fixing a typo (drat!) or suggesting an update ("yeah, this would be better").