Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update dependency @sentry/browser to v8 [SECURITY] #5797

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Oct 3, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
@sentry/browser (source) ^7.107.0 -> ^8.0.0 age adoption passing confidence

Test plan: CI should pass with updated dependencies. No review required: this is an automated dependency update PR.

Test plan: CI should pass with updated dependencies.

GitHub Vulnerability Alerts

GHSA-593m-55hh-j8gv

Impact

In case a Prototype Pollution vulnerability is present in a user's application or bundled libraries, the Sentry SDK could potentially serve as a gadget to exploit that vulnerability. The exploitability depends on the specific details of the underlying Prototype Pollution issue.

Note

This advisory does not indicate the presence of a Prototype Pollution within the Sentry SDK itself. Users are strongly advised to first address any Prototype Pollution vulnerabilities in their application, as they pose a more critical security risk.

Patches

The issue was patched in all Sentry JavaScript SDKs starting from the 8.33.0 version.

References


Release Notes

getsentry/sentry-javascript (@​sentry/browser)

v8.33.0

Compare Source

Important Changes
  • feat(nextjs): Support new async APIs (headers(), params, searchParams)
    (#​13828)

Adds support for new dynamic Next.js APIs.

  • feat(node): Add lru-memoizer instrumentation
    (#​13796)

Adds integration for lru-memoizer using @​opentelemetry/instrumentation-lru-memoizer.

  • feat(nuxt): Add unstable_sentryBundlerPluginOptions to module options
    (#​13811)

Allows passing other options from the bundler plugins (vite and rollup) to Nuxt module options.

Other Changes
  • fix(browser): Ensure wrap() only returns functions
    (#​13838)
  • fix(core): Adapt trpc middleware input attachment
    (#​13831)
  • fix(core): Don't return trace data in getTraceData and getTraceMetaTags if SDK is disabled
    (#​13760)
  • fix(nuxt): Don't restrict source map assets upload
    (#​13800)
  • fix(nuxt): Use absolute path for client config (#​13798)
  • fix(replay): Stop global event handling for paused replays
    (#​13815)
  • fix(sveltekit): add url param to source map upload options
    (#​13812)
  • fix(types): Add jsdocs to cron types (#​13776)
  • fix(nextjs): Loosen @​sentry/nextjs webpack peer dependency
    (#​13826)

Work in this release was contributed by @​joshuajaco. Thank you for your contribution!

Bundle size 📦
Path Size
@​sentry/browser 22.64 KB
@​sentry/browser - with treeshaking flags 21.42 KB
@​sentry/browser (incl. Tracing) 34.87 KB
@​sentry/browser (incl. Tracing, Replay) 71.37 KB
@​sentry/browser (incl. Tracing, Replay) - with treeshaking flags 61.8 KB
@​sentry/browser (incl. Tracing, Replay with Canvas) 75.72 KB
@​sentry/browser (incl. Tracing, Replay, Feedback) 88.49 KB
@​sentry/browser (incl. Tracing, Replay, Feedback, metrics) 90.37 KB
@​sentry/browser (incl. metrics) 26.91 KB
@​sentry/browser (incl. Feedback) 39.78 KB
@​sentry/browser (incl. sendFeedback) 27.3 KB
@​sentry/browser (incl. FeedbackAsync) 32.08 KB
@​sentry/react 25.39 KB
@​sentry/react (incl. Tracing) 37.85 KB
@​sentry/vue 26.8 KB
@​sentry/vue (incl. Tracing) 36.76 KB
@​sentry/svelte 22.77 KB
CDN Bundle 23.95 KB
CDN Bundle (incl. Tracing) 36.64 KB
CDN Bundle (incl. Tracing, Replay) 71.14 KB
CDN Bundle (incl. Tracing, Replay, Feedback) 76.45 KB
CDN Bundle - uncompressed 70.17 KB
CDN Bundle (incl. Tracing) - uncompressed 108.63 KB
CDN Bundle (incl. Tracing, Replay) - uncompressed 220.53 KB
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 233.74 KB
@​sentry/nextjs (client) 37.81 KB
@​sentry/sveltekit (client) 35.44 KB
@​sentry/node 125.13 KB
@​sentry/node - without tracing 93.58 KB
@​sentry/aws-serverless 103.28 KB

v8.32.0

Compare Source

Important Changes
  • ref(browser): Move navigation span descriptions into op
    (#​13527)

Moves the description of navigation related browser spans into the op, e.g. browser - cache -> browser.cache and sets
the description to the performanceEntry objects' names (in this context it is the URL of the page).

  • feat(node): Add amqplibIntegration (#​13714)

  • feat(nestjs): Add SentryGlobalGenericFilter and allow specifying application ref in global filter
    (#​13673)

Adds a SentryGlobalGenericFilter that filters both graphql and http exceptions depending on the context.

  • feat: Set log level for Fetch/XHR breadcrumbs based on status code
    (#​13711)

Sets log levels in breadcrumbs for 5xx to error and 4xx to warning.

Other Changes
  • chore(nextjs): Bump rollup to 3.29.5 (#​13761)
  • fix(core): Remove sampled flag from dynamic sampling context in Tracing without Performance mode
    (#​13753)
  • fix(node): Ensure node-fetch does not emit spans without tracing
    (#​13765)
  • fix(nuxt): Use Nuxt error hooks instead of errorHandler to prevent 500
    (#​13748)
  • fix(test): Unflake LCP test (#​13741)

Work in this release was contributed by @​Zen-cronic and @​Sjoertjuh. Thank you for your contributions!

v8.31.0

Compare Source

Important Changes
  • feat(node): Add dataloader integration (#​13664)

This release adds a new integration for the dataloader package. The Node
SDK (and all SDKs that depend on it) will now automatically instrument dataloader instances. You can also add it
manually:

Sentry.init({
  integrations: [Sentry.dataloaderIntegration()],
});
Other Changes
  • feat(browser): Add navigation activationStart timestamp to pageload span (#​13658)
  • feat(gatsby): Add optional deleteSourcemapsAfterUpload (#​13610)
  • feat(nextjs): Give app router prefetch requests a http.server.prefetch op (#​13600)
  • feat(nextjs): Improve Next.js serverside span data quality (#​13652)
  • feat(node): Add disableInstrumentationWarnings option (#​13693)
  • feat(nuxt): Adding experimental_basicServerTracing option to Nuxt module (#​13643)
  • feat(nuxt): Improve logs about adding Node option 'import' (#​13726)
  • feat(replay): Add onError callback + other small improvements to debugging (#​13721)
  • feat(replay): Add experimental option to allow for a checkout every 6 minutes (#​13069)
  • feat(wasm): Unconditionally parse instruction addresses (#​13655)
  • fix: Ensure all logs are wrapped with consoleSandbox (#​13690)
  • fix(browser): Try multiple options for lazyLoadIntegration script parent element lookup (#​13717)
  • fix(feedback): Actor color applies to feedback icon (#​13702)
  • fix(feedback): Fix form width on mobile devices (#​13068)
  • fix(nestjs): Preserve original function name on SentryTraced functions (#​13684)
  • fix(node): Don't overwrite local variables for re-thrown errors (#​13644)
  • fix(normalize): Treat Infinity as NaN both are non-serializable numbers (#​13406)
  • fix(nuxt): Use correct server output file path (#​13725)
  • fix(opentelemetry): Always use active span in Propagator.inject (#​13381)
  • fix(replay): Fixes potential out-of-order segments (#​13609)

Work in this release was contributed by @​KyGuy2002, @​artzhookov, and @​julianCast. Thank you for your contributions!

v8.30.0

Compare Source

Important Changes
  • feat(node): Add kafkajs integration (#​13528)

This release adds a new integration that instruments kafkajs library with spans and traces. This integration is
automatically enabled by default, but can be included with the Sentry.kafkaIntegration() import.

Sentry.init({
  integrations: [Sentry.kafkaIntegration()],
});
Other Changes
  • feat(core): Allow adding measurements without global client (#​13612)
  • feat(deps): Bump @​opentelemetry/instrumentation-undici from 0.5.0 to 0.6.0 (#​13622)
  • feat(deps): Bump @​sentry/cli from 2.33.0 to 2.35.0 (#​13624)
  • feat(node): Use @opentelemetry/instrumentation-undici for fetch tracing (#​13485)
  • feat(nuxt): Add server config to root folder (#​13583)
  • feat(otel): Upgrade @​opentelemetry/semantic-conventions to 1.26.0 (#​13631)
  • fix(browser): check supportedEntryTypes before caling the function (#​13541)
  • fix(browser): Ensure Standalone CLS span timestamps are correct (#​13649)
  • fix(nextjs): Widen removal of 404 transactions (#​13628)
  • fix(node): Remove ambiguity and race conditions when matching local variables to exceptions (#​13501)
  • fix(node): Update OpenTelemetry instrumentation package for solidstart and opentelemetry (#​13640)
  • fix(node): Update OpenTelemetry instrumentation package for solidstart and opentelemetry (#​13642)
  • fix(vue): Ensure Vue trackComponents list matches components with or without <> (#​13543)
  • ref(profiling): Conditionally shim cjs globals (#​13267)

Work in this release was contributed by @​Zen-cronic and @​odanado. Thank you for your contributions!

v8.29.0

Compare Source

Important Changes
  • Beta releases of official Solid and SolidStart Sentry SDKs

This release marks the beta releases of the @sentry/solid and @sentry/solidstart Sentry SDKs. For details on how to
use them, check out the
Sentry Solid SDK README and the
Sentry SolidStart SDK README
respectively. Please reach out on GitHub if you have
any feedback or concerns.

  • feat(node): Option to only wrap instrumented modules (#​13139)

Adds the SDK option to only wrap ES modules with import-in-the-middle that specifically need to be instrumented.

import * as Sentry from '@&#8203;sentry/node';

Sentry.init({
  dsn: '__PUBLIC_DSN__',
  registerEsmLoaderHooks: { onlyHookedModules: true },
});
  • feat(node): Update OpenTelemetry packages to instrumentation v0.53.0 (#​13587)

All internal OpenTelemetry instrumentation was updated to their latest version. This adds support for Mongoose v7 and v8
and fixes various bugs related to ESM mode.

Other Changes
  • feat(nextjs): Emit warning when using turbopack (#​13566)
  • feat(nextjs): Future-proof Next.js config options overriding (#​13586)
  • feat(node): Add generic-pool integration (#​13465)
  • feat(nuxt): Upload sourcemaps generated by Nitro (#​13382)
  • feat(solidstart): Add browserTracingIntegration by default (#​13561)
  • feat(solidstart): Add sentrySolidStartVite plugin to simplify source maps upload (#​13493)
  • feat(vue): Only start UI spans if parent is available (#​13568)
  • fix(cloudflare): Guard context.waitUntil call in request handler (#​13549)
  • fix(gatsby): Fix assets path for sourcemaps upload (#​13592)
  • fix(nextjs): Use posix paths for sourcemap uploads (#​13603)
  • fix(node-fetch): Use stringified origin url (#​13581)
  • fix(node): Replace dashes in generic-pool span origins with underscores (#​13579)
  • fix(replay): Fix types in WebVitalData (#​13573)
  • fix(replay): Improve replay web vital types (#​13602)
  • fix(utils): Keep logger on carrier (#​13570)

Work in this release was contributed by @​Zen-cronic. Thank you for your contribution!

v8.28.0

Compare Source

Important Changes
  • Beta release of official NestJS SDK

This release contains the beta version of @sentry/nestjs! For details on how to use it, check out the
README. Any feedback/bug reports
are greatly appreciated, please reach out on GitHub.

  • fix(browser): Remove faulty LCP, FCP and FP normalization logic (#​13502)

This release fixes a bug in the @sentry/browser package and all SDKs depending on this package (e.g. @sentry/react
or @sentry/nextjs) that caused the SDK to send incorrect web vital values for the LCP, FCP and FP vitals. The SDK
previously incorrectly processed the original values as they were reported from the browser. When updating your SDK to
this version, you might experience an increase in LCP, FCP and FP values, which potentially leads to a decrease in your
performance score in the Web Vitals Insights module in Sentry. This is because the previously reported values were
smaller than the actually measured values. We apologize for the inconvenience!

Other Changes
  • feat(nestjs): Add SentryGlobalGraphQLFilter (#​13545)
  • feat(nestjs): Automatic instrumentation of nestjs interceptors after route execution (#​13264)
  • feat(nextjs): Add bundleSizeOptimizations to build options (#​13323)
  • feat(nextjs): Stabilize captureRequestError (#​13550)
  • feat(nuxt): Wrap config in nuxt context (#​13457)
  • feat(profiling): Expose profiler as top level primitive (#​13512)
  • feat(replay): Add layout shift to CLS replay data (#​13386)
  • feat(replay): Upgrade rrweb packages to 2.26.0 (#​13483)
  • fix(cdn): Do not mangle _metadata (#​13426)
  • fix(cdn): Fix SDK source for CDN bundles (#​13475)
  • fix(nestjs): Check arguments before instrumenting with @Injectable (#​13544)
  • fix(nestjs): Ensure exception and host are correctly passed on when using @​WithSentry (#​13564)
  • fix(node): Suppress tracing for transport request execution rather than transport creation (#​13491)
  • fix(replay): Consider more things as DOM mutations for dead clicks (#​13518)
  • fix(vue): Correctly obtain component name (#​13484)

Work in this release was contributed by @​leopoldkristjansson, @​mhuggins and @​filips123. Thank you for your
contributions!

v8.27.0

Compare Source

Important Changes
  • fix(nestjs): Exception filters in main app module are not being executed (#​13278)

    With this release nestjs error monitoring is no longer automatically set up after adding the SentryModule to your
    application, which led to issues in certain scenarios. You will now have to either add the SentryGlobalFilter to
    your main module providers or decorate the catch() method in your existing global exception filters with the newly
    released @WithSentry() decorator. See the docs for
    more details.

Other Changes
  • feat: Add options for passing nonces to feedback integration (#​13347)
  • feat: Add support for SENTRY_SPOTLIGHT env var in Node (#​13325)
  • feat(deps): bump @​prisma/instrumentation from 5.17.0 to 5.18.0 (#​13327)
  • feat(feedback): Improve error message for 403 errors (#​13441)
  • fix(deno): Don't rely on Deno.permissions.querySync (#​13378)
  • fix(replay): Ensure we publish replay CDN bundles (#​13437)

Work in this release was contributed by @​charpeni. Thank you for your contribution!

v8.26.0

Compare Source

Important Changes
  • feat(node): Add fsInstrumentation (#​13291)

    This release adds fsIntegration, an integration that instruments the fs API to the Sentry Node SDK. The
    integration creates spans with naming patterns of fs.readFile, fs.unlink, and so on.

    This integration is not enabled by default and needs to be registered in your Sentry.init call. You can configure
    via options whether to include path arguments or error messages as span attributes when an fs call fails:

    Sentry.init({
      integrations: [
        Sentry.fsIntegration({
          recordFilePaths: true,
          recordErrorMessagesAsSpanAttributes: true,
        }),
      ],
    });

    WARNING: This integration may add significant overhead to your application. Especially in scenarios with a lot of
    file I/O, like for example when running a framework dev server, including this integration can massively slow down
    your application.

Other Changes
  • feat(browser): Add spotlightBrowser integration (#​13263)

  • feat(browser): Allow sentry in safari extension background page (#​13209)

  • feat(browser): Send CLS as standalone span (experimental) (#​13056)

  • feat(core): Add OpenTelemetry-specific getTraceData implementation (#​13281)

  • feat(nextjs): Always add browserTracingIntegration (#​13324)

  • feat(nextjs): Always transmit trace data to the client (#​13337)

  • feat(nextjs): export SentryBuildOptions (#​13296)

  • feat(nextjs): Update experimental_captureRequestError to reflect RequestInfo.path change in Next.js canary
    (#​13344)

  • feat(nuxt): Always add tracing meta tags (#​13273)

  • feat(nuxt): Set transaction name for server error (#​13292)

  • feat(replay): Add a replay-specific logger (#​13256)

  • feat(sveltekit): Add bundle size optimizations to plugin options (#​13318)

  • feat(sveltekit): Always add browserTracingIntegration (#​13322)

  • feat(tracing): Make long animation frames opt-out (#​13255)

  • fix(astro): Correctly extract request data (#​13315)

  • fix(astro): Only track access request headers in dynamic page requests (#​13306)

  • fix(nuxt): Add import line for disabled autoImport (#​13342)

  • fix(nuxt): Add vue to excludeEsmLoaderHooks array (#​13346)

  • fix(opentelemetry): Do not overwrite http span name if kind is internal (#​13282)

  • fix(remix): Ensure origin is correctly set for remix server spans (#​13305)

Work in this release was contributed by @​MonstraG, @​undead-voron and @​Zen-cronic. Thank you for your contributions!

v8.25.0

Compare Source

Important Changes
  • Alpha release of Official Solid Start SDK

This release contains the alpha version of @sentry/solidstart, our SDK for Solid Start!
For details on how to use it, please see the README. Any feedback/bug reports are
greatly appreciated, please reach out on GitHub.

Other Changes
  • feat(astro): Add bundleSizeOptimizations vite options to integration (#​13250)
  • feat(astro): Always add BrowserTracing (#​13244)
  • feat(core): Add getTraceMetaTags function (#​13201)
  • feat(nestjs): Automatic instrumentation of nestjs exception filters (#​13230)
  • feat(node): Add useOperationNameForRootSpan tographqlIntegration (#​13248)
  • feat(sveltekit): Add wrapServerRouteWithSentry wrapper (#​13247)
  • fix(aws-serverless): Extract sentry trace data from handler context over event (#​13266)
  • fix(browser): Initialize default integration if defaultIntegrations: undefined (#​13261)
  • fix(utils): Streamline IP capturing on incoming requests (#​13272)

v8.24.0

Compare Source

  • feat(nestjs): Filter RPC exceptions (#​13227)
  • fix: Guard getReader function for other fetch implementations (#​13246)
  • fix(feedback): Ensure feedback can be lazy loaded in CDN bundles (#​13241)

v8.23.0

Compare Source

Important Changes
  • feat(cloudflare): Add Cloudflare D1 instrumentation (#​13142)

This release includes support for Cloudflare D1, Cloudflare's serverless SQL database. To instrument your Cloudflare D1
database, use the instrumentD1WithSentry method as follows:

// env.DB is the D1 DB binding configured in your `wrangler.toml`
const db = instrumentD1WithSentry(env.DB);
// Now you can use the database as usual
await db.prepare('SELECT * FROM table WHERE id = ?').bind(1).run();
Other Changes
  • feat(cloudflare): Allow users to pass handler to sentryPagesPlugin (#​13192)
  • feat(cloudflare): Instrument scheduled handler (#​13114)
  • feat(core): Add getTraceData function (#​13134)
  • feat(nestjs): Automatic instrumentation of nestjs interceptors before route execution (#​13153)
  • feat(nestjs): Automatic instrumentation of nestjs pipes (#​13137)
  • feat(nuxt): Filter out Nuxt build assets (#​13148)
  • feat(profiling): Attach sdk info to chunks (#​13145)
  • feat(solidstart): Add sentry onBeforeResponse middleware to enable distributed tracing (#​13221)
  • feat(solidstart): Filter out low quality transactions for build assets (#​13222)
  • fix(browser): Avoid showing browser extension error message in non-window global scopes (#​13156)
  • fix(feedback): Call dialog.close() in dialog close callbacks in \_loadAndRenderDialog (#​13203)
  • fix(nestjs): Inline Observable type to resolve missing 'rxjs' dependency (#​13166)
  • fix(nuxt): Detect pageload by adding flag in Vue router (#​13171)
  • fix(utils): Handle when requests get aborted in fetch instrumentation (#​13202)
  • ref(browser): Improve browserMetrics collection (#​13062)

Work in this release was contributed by @​horochx. Thank you for your contribution!

v8.22.0

Compare Source

Important Changes
  • feat(cloudflare): Add plugin for cloudflare pages (#​13123)

This release adds support for Cloudflare Pages to @sentry/cloudflare, our SDK for the
Cloudflare Workers JavaScript Runtime! For details on how to use it,
please see the README. Any feedback/bug reports are greatly appreciated, please
reach out on GitHub.

// functions/_middleware.js
import * as Sentry from '@&#8203;sentry/cloudflare';

export const onRequest = Sentry.sentryPagesPlugin({
  dsn: __PUBLIC_DSN__,
  // Set tracesSampleRate to 1.0 to capture 100% of spans for tracing.
  tracesSampleRate: 1.0,
});
Other Changes
  • feat(meta-sdks): Remove runtime tags (#​13105)
  • feat(nestjs): Automatic instrumentation of nestjs guards (#​13129)
  • feat(nestjs): Filter all HttpExceptions (#​13120)
  • feat(replay): Capture exception when internal_sdk_error client report happens (#​13072)
  • fix: Use globalThis for code injection (#​13132)

v8.21.0

Compare Source

Important Changes
  • Alpha release of Official Cloudflare SDK
    • feat(cloudflare): Add withSentry method (#​13025)
    • feat(cloudflare): Add cloudflare sdk scaffolding (#​12953)
    • feat(cloudflare): Add basic cloudflare package and tests (#​12861)

This release contains the alpha version of @sentry/cloudflare, our SDK for the
Cloudflare Workers JavaScript Runtime! For details on how to use it,
please see the README. Any feedback/bug reports are greatly appreciated, please
reach out on GitHub.

Please note that only Cloudflare Workers are tested and supported - official Cloudflare Pages support will come in an
upcoming release.

Other Changes

v8.20.0

Compare Source

Important Changes
  • feat(node): Allow to pass registerEsmLoaderHooks to preload (#​12998)

You can write your own custom preload script and configure this in the preload options. registerEsmLoaderHooks can be
passed as an option to preloadOpenTelemetry, which allows to exclude/include packages in the preload.

  • fix(node): Do not emit fetch spans when tracing is disabled (#​13003)

Sentry will not emit "fetch" spans if tracing is disabled. This is relevant for user who use their own sampler.

Other Changes
  • feat(feedback): Trigger button aria label configuration (#​13008)
  • feat(nestjs): Change nest sdk setup (#​12920)
  • feat(node): Extend ESM hooks options for iitm v1.10.0 (#​13016)
  • feat(node): Send client reports (#​12951)
  • feat(nuxt): Automatically add BrowserTracing (#​13005)
  • feat(nuxt): Setup source maps with vite config (#​13018)
  • feat(replay): Improve public Replay APIs (#​13000)

v8.19.0

Compare Source

node --import=@​sentry/node/import app.js


- **feat(node): Do not exit process by default when other `onUncaughtException` handlers are registered in
  `onUncaughtExceptionIntegration` (#&#8203;11532)**

In v8, we will no longer exit the node process by default if other uncaught exception handlers have been registered by
the user.

- **Better handling of transaction name for errors**

We improved the way we keep the transaction name for error events, even when spans are not sampled or performance is
disabled.

- feat(fastify): Update scope `transactionName` when handling request (#&#8203;11447)
- feat(hapi): Update scope `transactionName` when handling request (#&#8203;11448)
- feat(koa): Update scope `transactionName` when creating router span (#&#8203;11476)
- feat(sveltekit): Update scope transactionName when handling server-side request (#&#8203;11511)
- feat(nestjs): Update scope transaction name with parameterized route (#&#8203;11510)

##### Removal/Refactoring of deprecated functionality

- feat(core): Remove `getCurrentHub` from `AsyncContextStrategy` (#&#8203;11581)
- feat(core): Remove `getGlobalHub` export (#&#8203;11565)
- feat(core): Remove `Hub` class export (#&#8203;11560)
- feat(core): Remove most Hub class exports (#&#8203;11536)
- feat(nextjs): Remove webpack 4 support (#&#8203;11605)
- feat(vercel-edge): Stop using hub (#&#8203;11539)

##### Other Changes

- feat: Hoist `getCurrentHub` shim to core as `getCurrentHubShim` (#&#8203;11537)
- feat(core): Add default behaviour for `rewriteFramesIntegration` in browser (#&#8203;11535)
- feat(core): Ensure replay envelopes are sent in order when offline (#&#8203;11413)
- feat(core): Extract errors from props in unkown inputs (#&#8203;11526)
- feat(core): Update metric normalization (#&#8203;11518)
- feat(feedback): Customize feedback placeholder text color (#&#8203;11417)
- feat(feedback): Maintain v7 compat in the @&#8203;sentry-internal/feedback package (#&#8203;11461)
- feat(next): Handle existing root spans for isolation scope (#&#8203;11479)
- feat(node): Ensure tracing without performance (TWP) works (#&#8203;11564)
- feat(opentelemetry): Export `getRequestSpanData` (#&#8203;11508)
- feat(opentelemetry): Remove otel.attributes in context (#&#8203;11604)
- feat(ratelimit): Add metrics rate limit (#&#8203;11538)
- feat(remix): Skip span creation for `OPTIONS` and `HEAD` requests. (#&#8203;11149)
- feat(replay): Merge packages together & ensure bundles are built (#&#8203;11552)
- feat(tracing): Adds span envelope and datacategory (#&#8203;11534)
- fix(browser): Ensure pageload trace remains active after pageload span finished (#&#8203;11600)
- fix(browser): Ensure tracing without performance (TWP) works (#&#8203;11561)
- fix(nextjs): Fix `tunnelRoute` matching logic for hybrid cloud (#&#8203;11576)
- fix(nextjs): Remove Http integration from Next.js (#&#8203;11304)
- fix(node): Ensure isolation scope is correctly cloned for non-recording spans (#&#8203;11503)
- fix(node): Make fastify types more broad (#&#8203;11544)
- fix(node): Send ANR events without scope if event loop blocked indefinitely (#&#8203;11578)
- fix(tracing): Fixes latest route name and source not updating correctly (#&#8203;11533)
- ref(browser): Move browserTracing into browser pkg (#&#8203;11484)
- ref(feedback): Configure font size (#&#8203;11437)
- ref(feedback): Refactor Feedback types into @&#8203;sentry/types and reduce the exported surface area (#&#8203;11355)

#### 8.0.0-beta.0

This release failed to publish correctly. Use 8.0.0-beta.1 instead.

#### 8.0.0-alpha.9

This is the eighth alpha release of Sentry JavaScript SDK v8, which includes a variety of breaking changes.

Read the [in-depth migration guide](./MIGRATION.md) to find out how to address any breaking changes in your code.

##### Important Changes

- **feat: Add @&#8203;sentry-internal/browser-utils (#&#8203;11381)**

A big part of the browser-runtime specific exports of the internal `@sentry/utils` package were moved into a new package
`@sentry-internal/browser-utils`. If you imported any API from `@sentry/utils` (which is generally not recommended but
necessary for some workarounds), please check that your import statements still point to existing exports after
upgrading.

- **feat: Add loader file to node-based SDKs to support ESM monkeypatching (#&#8203;11338)**

When using ESM, it is necessary to use a "loader" to be able to instrument certain third-party packages and Node.js API.
The server-side SDKs now ship with a set of ESM loader hooks, that should be used when using ESM. Use them as follows:

```sh

v8.18.0

Compare Source

Important Changes
  • ref: Deprecate enableTracing (12897)

The enableTracing option has been deprecated and will be removed in the next major version. We recommend removing it
in favor of the tracesSampleRate and tracesSampler options. If you want to enable performance monitoring, please set
the tracesSampleRate to a sample rate of your choice, or provide a sampling function as tracesSampler option
instead. If you want to disable performance monitoring, remove the tracesSampler and tracesSampleRate options.

Other Changes
  • feat(node): Expose exclude and include options for ESM loader (#​12910)
  • feat(browser): Add user agent to INP standalone span attributes (#​12896)
  • feat(nextjs): Add experimental_captureRequestError for onRequestError hook (#​12885)
  • feat(replay): Bump rrweb to 2.25.0 (#​12478)
  • feat(tracing): Add long animation frame tracing (#​12646)
  • fix: Cleanup hooks when they are not used anymore (#​12852)
  • fix(angular): Guard ErrorEvent check in ErrorHandler to avoid throwing in Node environments (#​12892)
  • fix(inp): Ensure INP spans have correct transaction (#​12871)
  • fix(nestjs): Do not make SentryTraced() decorated functions async (#​12879)
  • fix(nextjs): Support automatic instrumentation for app directory with custom page extensions (#​12858)
  • fix(node): Ensure correct URL is passed to ignoreIncomingRequests callback (#​12929)
  • fix(otel): Do not add otel.kind: INTERNAL attribute (#​12841)
  • fix(solidstart): Set proper sentry origin for solid router integration when used in solidstart sdk (#​12919)
  • fix(sveltekit): Add Vite peer dep for proper type resolution (#​12926)
  • fix(tracing): Ensure you can pass null as parentSpan in startSpan* (#​12928)
  • ref(core): Small bundle size improvement (#​12830)

Work in this release was contributed by @​GitSquared and @​mcous. Thank you for your contributions!

Bundle size 📦

Path Size
@​sentry/browser 22.3 KB
@​sentry/browser (incl. Tracing) 33.69 KB
@​sentry/browser (incl. Tracing, Replay) 69.77 KB
@​sentry/browser (incl. Tracing, Replay) - with treeshaking flags 63.08 KB
@​sentry/browser (incl. Tracing, Replay with Canvas) 74.17 KB
@​sentry/browser (incl. Tracing, Replay, Feedback) 86.49 KB
@​sentry/browser (incl. Tracing, Replay, Feedback, metrics) 88.36 KB
@​sentry/browser (incl. metrics) 26.59 KB
@​sentry/browser (incl. Feedback) 38.98 KB
@​sentry/browser (incl. sendFeedback) 26.93 KB
@​sentry/browser (incl. FeedbackAsync) 31.54 KB
@​sentry/react 25.06 KB
@​sentry/react (incl. Tracing) 36.75 KB
@​sentry/vue 26.41 KB
@​sentry/vue (incl. Tracing) 35.57 KB
@​sentry/svelte 22.44 KB
CDN Bundle 23.52 KB
CDN Bundle (incl. Tracing) 35.47 KB
CDN Bundle (incl. Tracing, Replay) 69.87 KB
CDN Bundle (incl. Tracing, Replay, Feedback) 75.14 KB
CDN Bundle - uncompressed 69 KB
CDN Bundle (incl. Tracing) - uncompressed 104.93 KB
CDN Bundle (incl. Tracing, Replay) - uncompressed 216.71 KB
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 229.43 KB
@​sentry/nextjs (client) 36.61 KB
@​sentry/sveltekit (client) 34.34 KB
@​sentry/node 130.83 KB
@​sentry/node - without tracing 91.91 KB
@​sentry/aws-serverless 117.08 KB

v8.17.0

Compare Source

  • feat: Upgrade OTEL deps (#​12809)
  • fix(nuxt): Add module to build:transpile script (#​12843)
  • fix(browser): Allow SDK initialization in NW.js apps (#​12846)

v8.16.0

Compare Source

Important Changes
  • feat(nextjs): Use spans generated by Next.js for App Router (#​12729)

Previously, the @sentry/nextjs SDK automatically recorded spans in the form of transactions for each of your top-level
server components (pages, layouts, ...). This approach had a few drawbacks, the main ones being that traces didn't have
a root span, and more importantly, if you had data stream to the client, its duration was not captured because the
server component spans had finished before the data could finish streaming.

With this release, we will capture the duration of App Router requests in their entirety as a single transaction with
server component spans being descendants of that transaction. This means you will get more data that is also more
accurate. Note that this does not apply to the Edge runtime. For the Edge runtime, the SDK will emit transactions as it
has before.

General


Configuration

📅 Schedule: Branch creation - "" in timezone America/Los_Angeles, Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Never, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants