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

feat(browser): Add browserSessionIntegration #14551

Merged
merged 7 commits into from
Dec 4, 2024

Conversation

lforst
Copy link
Member

@lforst lforst commented Dec 3, 2024

Ref: #14550

Adds a browserSessionIntegration that is exported from all browser SDKs which is added when autoSessionTracking: true, and entails the exact same functionality as autoSessionTracking does today.

In v9 this integration will become more fleshed out and completely replace autoSessionTracking in the browser SDKs.

Copy link

codecov bot commented Dec 3, 2024

❌ 1 Tests Failed:

Tests completed Failed Passed Skipped
537 1 536 151
View the top 1 failed tests by shortest run time
public-api/debug/test.ts logs debug messages correctly
Stack Traces | 0.178s run time
test.ts:7:11 logs debug messages correctly

To view more test analytics, go to the Test Analytics Dashboard
📢 Thoughts on this report? Let us know!

Copy link
Contributor

github-actions bot commented Dec 3, 2024

size-limit report 📦

Path Size % Change Change
@sentry/browser 23.17 KB +0.19% +44 B 🔺
@sentry/browser - with treeshaking flags 21.85 KB -0.01% -2 B 🔽
@sentry/browser (incl. Tracing) 35.66 KB +0.16% +58 B 🔺
@sentry/browser (incl. Tracing, Replay) 72.57 KB +0.13% +96 B 🔺
@sentry/browser (incl. Tracing, Replay) - with treeshaking flags 62.99 KB +0.04% +24 B 🔺
@sentry/browser (incl. Tracing, Replay with Canvas) 76.88 KB +0.11% +82 B 🔺
@sentry/browser (incl. Tracing, Replay, Feedback) 89.36 KB +0.09% +78 B 🔺
@sentry/browser (incl. Feedback) 39.93 KB +0.13% +51 B 🔺
@sentry/browser (incl. sendFeedback) 27.78 KB +0.15% +41 B 🔺
@sentry/browser (incl. FeedbackAsync) 32.57 KB +0.07% +21 B 🔺
@sentry/react 25.84 KB +0.13% +34 B 🔺
@sentry/react (incl. Tracing) 38.47 KB -0.06% -20 B 🔽
@sentry/vue 27.37 KB +0.41% +112 B 🔺
@sentry/vue (incl. Tracing) 37.49 KB +0.27% +101 B 🔺
@sentry/svelte 23.33 KB +0.27% +64 B 🔺
CDN Bundle 24.33 KB +0.04% +8 B 🔺
CDN Bundle (incl. Tracing) 37.32 KB +0.05% +16 B 🔺
CDN Bundle (incl. Tracing, Replay) 72.19 KB +0.04% +24 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback) 77.53 KB +0.03% +21 B 🔺
CDN Bundle - uncompressed 71.5 KB +0.07% +51 B 🔺
CDN Bundle (incl. Tracing) - uncompressed 110.78 KB +0.05% +51 B 🔺
CDN Bundle (incl. Tracing, Replay) - uncompressed 223.85 KB +0.03% +51 B 🔺
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 237.07 KB +0.03% +51 B 🔺
@sentry/nextjs (client) 38.77 KB -0.05% -19 B 🔽
@sentry/sveltekit (client) 36.15 KB +0.03% +10 B 🔺
@sentry/node 134.83 KB +0.01% +1 B 🔺
@sentry/node - without tracing 96.84 KB +0.01% +1 B 🔺
@sentry/aws-serverless 109.17 KB -0.01% -1 B 🔽

View base workflow run

@lforst lforst marked this pull request as ready for review December 3, 2024 11:43
@lforst lforst requested a review from a team as a code owner December 3, 2024 11:43
// concept that can be used as a metric.
// Automatically captured sessions are akin to page views, and thus we
// discard their duration.
startSession({ ignoreDuration: true });
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we adjust the startSession syntax to allow to optionally pass a client directly, and run all of this on setup(client) instead of setupOnce()? 🤔

Then again all of this is kind of global, so maybe this does not help anyhow 🤔

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I had the same thoughts. I am actually extremely unsure on how to proceed. It all depends on how we would want sessions to work. If we want there to be multiple at once, it would make sense, however I would err towards the exact opposite.

I think always only having one session active per page makes the most sense. Even in MFEs. I would even go so far to lock down the API down even more in v9, simply because it makes wrapping your head around the concept easier.

All of this is just thinking out loud though. In general I didn't want this PR to be behaviorally significant. That's why I chose this route.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this makes sense to me!

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree, let's leave it at one "global" session per page.

@lforst lforst requested review from Lms24 and AbhiPrasad December 3, 2024 12:47
Copy link
Member

@Lms24 Lms24 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice!

@@ -34,7 +34,7 @@ sentryTest('should capture replays (@sentry/browser export)', async ({ getLocalT
event_id: expect.stringMatching(/\w{32}/),
environment: 'production',
sdk: {
integrations: [
integrations: expect.arrayContaining([
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

l: any reason to loosen the assertions?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I personally found it to be very annoying that the ordering needed to be exact. Lmk if you want me to change it back.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah I see, the ordering is annoying, agreed. Though these tests wouldn't fail additionally added integrations, unless I'm completely missing something. So that opens the test up to more behaviour change than previously. I don't think this is the end of the world but it'd be good to have at least one test that fails if we add a new integration by default. We should be aware of stuff like this.

@lforst lforst merged commit 7f36772 into develop Dec 4, 2024
149 checks passed
@lforst lforst deleted the lforst-expose-browser-session-integration branch December 4, 2024 15:16
alexandresoro pushed a commit to alexandresoro/ouca that referenced this pull request Dec 22, 2024
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [@sentry/node](https://github.com/getsentry/sentry-javascript/tree/master/packages/node) ([source](https://github.com/getsentry/sentry-javascript)) | dependencies | minor | [`8.42.0` -> `8.47.0`](https://renovatebot.com/diffs/npm/@sentry%2fnode/8.42.0/8.47.0) |
| [@sentry/react](https://github.com/getsentry/sentry-javascript/tree/master/packages/react) ([source](https://github.com/getsentry/sentry-javascript)) | dependencies | minor | [`8.42.0` -> `8.47.0`](https://renovatebot.com/diffs/npm/@sentry%2freact/8.42.0/8.47.0) |

---

### Release Notes

<details>
<summary>getsentry/sentry-javascript (@&#8203;sentry/node)</summary>

### [`v8.47.0`](https://github.com/getsentry/sentry-javascript/releases/tag/8.47.0)

[Compare Source](getsentry/sentry-javascript@8.46.0...8.47.0)

-   feat(v8/core): Add `updateSpanName` helper function ([#&#8203;14736](getsentry/sentry-javascript#14736))
-   feat(v8/node): Do not overwrite prisma `db.system` in newer Prisma versions ([#&#8203;14772](getsentry/sentry-javascript#14772))
-   feat(v8/node/deps): Bump [@&#8203;prisma/instrumentation](https://github.com/prisma/instrumentation) from 5.19.1 to 5.22.0 ([#&#8203;14755](getsentry/sentry-javascript#14755))
-   feat(v8/replay): Mask srcdoc iframe contents per default ([#&#8203;14779](getsentry/sentry-javascript#14779))
-   ref(v8/nextjs): Fix typo in source maps deletion warning ([#&#8203;14776](getsentry/sentry-javascript#14776))

Work in this release was contributed by [@&#8203;aloisklink](https://github.com/aloisklink) and [@&#8203;benjick](https://github.com/benjick). Thank you for your contributions!

##### Bundle size 📦

| Path                                                             | Size              |
| ---------------------------------------------------------------- | ----------------- |
| [@&#8203;sentry/browser](https://github.com/sentry/browser)                                                  | 23.29 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) - with treeshaking flags                         | 21.96 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing)                                  | 35.81 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay)                          | 73.06 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay) - with treeshaking flags | 63.45 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay with Canvas)              | 77.37 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay, Feedback)                | 89.85 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Feedback)                                 | 40.04 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. sendFeedback)                             | 27.89 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. FeedbackAsync)                            | 32.68 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react)                                                    | 25.96 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react) (incl. Tracing)                                    | 38.64 KB  |
| [@&#8203;sentry/vue](https://github.com/sentry/vue)                                                      | 27.52 KB  |
| [@&#8203;sentry/vue](https://github.com/sentry/vue) (incl. Tracing)                                      | 37.67 KB  |
| [@&#8203;sentry/svelte](https://github.com/sentry/svelte)                                                   | 23.45 KB  |
| CDN Bundle                                                       | 24.47 KB  |
| CDN Bundle (incl. Tracing)                                       | 37.51 KB  |
| CDN Bundle (incl. Tracing, Replay)                               | 72.71 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback)                     | 78.1 KB   |
| CDN Bundle - uncompressed                                        | 71.85 KB  |
| CDN Bundle (incl. Tracing) - uncompressed                        | 111.23 KB |
| CDN Bundle (incl. Tracing, Replay) - uncompressed                | 225.3 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed      | 238.52 KB |
| [@&#8203;sentry/nextjs](https://github.com/sentry/nextjs) (client)                                          | 38.9 KB   |
| [@&#8203;sentry/sveltekit](https://github.com/sentry/sveltekit) (client)                                       | 36.32 KB  |
| [@&#8203;sentry/node](https://github.com/sentry/node)                                                     | 162.7 KB  |
| [@&#8203;sentry/node](https://github.com/sentry/node) - without tracing                                   | 98.87 KB  |
| [@&#8203;sentry/aws-serverless](https://github.com/sentry/aws-serverless)                                           | 126.53 KB |

### [`v8.46.0`](https://github.com/getsentry/sentry-javascript/releases/tag/8.46.0)

[Compare Source](getsentry/sentry-javascript@8.45.1...8.46.0)

-   feat: Allow capture of more than 1 ANR event \[v8] ([#&#8203;14713](getsentry/sentry-javascript#14713))
-   feat(node): Detect Railway release name \[v8] ([#&#8203;14714](getsentry/sentry-javascript#14714))
-   fix: Normalise ANR debug image file paths if appRoot was supplied \[v8] ([#&#8203;14709](getsentry/sentry-javascript#14709))
-   fix(nuxt): Remove build config from tsconfig ([#&#8203;14737](getsentry/sentry-javascript#14737))

Work in this release was contributed by [@&#8203;conor-ob](https://github.com/conor-ob). Thank you for your contribution!

##### Bundle size 📦

| Path                                                             | Size              |
| ---------------------------------------------------------------- | ----------------- |
| [@&#8203;sentry/browser](https://github.com/sentry/browser)                                                  | 23.29 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) - with treeshaking flags                         | 21.96 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing)                                  | 35.79 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay)                          | 73.01 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay) - with treeshaking flags | 63.41 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay with Canvas)              | 77.32 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay, Feedback)                | 89.81 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Feedback)                                 | 40.04 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. sendFeedback)                             | 27.89 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. FeedbackAsync)                            | 32.68 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react)                                                    | 25.96 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react) (incl. Tracing)                                    | 38.6 KB   |
| [@&#8203;sentry/vue](https://github.com/sentry/vue)                                                      | 27.49 KB  |
| [@&#8203;sentry/vue](https://github.com/sentry/vue) (incl. Tracing)                                      | 37.63 KB  |
| [@&#8203;sentry/svelte](https://github.com/sentry/svelte)                                                   | 23.45 KB  |
| CDN Bundle                                                       | 24.43 KB  |
| CDN Bundle (incl. Tracing)                                       | 37.46 KB  |
| CDN Bundle (incl. Tracing, Replay)                               | 72.64 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback)                     | 78.01 KB  |
| CDN Bundle - uncompressed                                        | 71.74 KB  |
| CDN Bundle (incl. Tracing) - uncompressed                        | 111.05 KB |
| CDN Bundle (incl. Tracing, Replay) - uncompressed                | 225.1 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed      | 238.32 KB |
| [@&#8203;sentry/nextjs](https://github.com/sentry/nextjs) (client)                                          | 38.88 KB  |
| [@&#8203;sentry/sveltekit](https://github.com/sentry/sveltekit) (client)                                       | 36.29 KB  |
| [@&#8203;sentry/node](https://github.com/sentry/node)                                                     | 162.53 KB |
| [@&#8203;sentry/node](https://github.com/sentry/node) - without tracing                                   | 98.72 KB  |
| [@&#8203;sentry/aws-serverless](https://github.com/sentry/aws-serverless)                                           | 126.4 KB  |

### [`v8.45.1`](https://github.com/getsentry/sentry-javascript/releases/tag/8.45.1)

[Compare Source](getsentry/sentry-javascript@8.45.0...8.45.1)

-   fix(feedback): Return when the `sendFeedback` promise resolves ([#&#8203;14683](getsentry/sentry-javascript#14683))

Work in this release was contributed by [@&#8203;antonis](https://github.com/antonis). Thank you for your contribution!

##### Bundle size 📦

| Path                                                             | Size              |
| ---------------------------------------------------------------- | ----------------- |
| [@&#8203;sentry/browser](https://github.com/sentry/browser)                                                  | 23.29 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) - with treeshaking flags                         | 21.96 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing)                                  | 35.79 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay)                          | 73.01 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay) - with treeshaking flags | 63.41 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay with Canvas)              | 77.32 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Tracing, Replay, Feedback)                | 89.81 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. Feedback)                                 | 40.04 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. sendFeedback)                             | 27.89 KB  |
| [@&#8203;sentry/browser](https://github.com/sentry/browser) (incl. FeedbackAsync)                            | 32.68 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react)                                                    | 25.96 KB  |
| [@&#8203;sentry/react](https://github.com/sentry/react) (incl. Tracing)                                    | 38.6 KB   |
| [@&#8203;sentry/vue](https://github.com/sentry/vue)                                                      | 27.49 KB  |
| [@&#8203;sentry/vue](https://github.com/sentry/vue) (incl. Tracing)                                      | 37.63 KB  |
| [@&#8203;sentry/svelte](https://github.com/sentry/svelte)                                                   | 23.45 KB  |
| CDN Bundle                                                       | 24.43 KB  |
| CDN Bundle (incl. Tracing)                                       | 37.46 KB  |
| CDN Bundle (incl. Tracing, Replay)                               | 72.64 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback)                     | 78.01 KB  |
| CDN Bundle - uncompressed                                        | 71.74 KB  |
| CDN Bundle (incl. Tracing) - uncompressed                        | 111.05 KB |
| CDN Bundle (incl. Tracing, Replay) - uncompressed                | 225.1 KB  |
| CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed      | 238.32 KB |
| [@&#8203;sentry/nextjs](https://github.com/sentry/nextjs) (client)                                          | 38.88 KB  |
| [@&#8203;sentry/sveltekit](https://github.com/sentry/sveltekit) (client)                                       | 36.29 KB  |
| [@&#8203;sentry/node](https://github.com/sentry/node)                                                     | 162.52 KB |
| [@&#8203;sentry/node](https://github.com/sentry/node) - without tracing                                   | 98.71 KB  |
| [@&#8203;sentry/aws-serverless](https://github.com/sentry/aws-serverless)                                           | 126.39 KB |

### [`v8.45.0`](https://github.com/getsentry/sentry-javascript/blob/HEAD/CHANGELOG.md#8450)

[Compare Source](getsentry/sentry-javascript@8.44.0...8.45.0)

-   feat(core): Add `handled` option to `captureConsoleIntegration` ([#&#8203;14664](getsentry/sentry-javascript#14664))
-   feat(browser): Attach virtual stack traces to `HttpClient` events ([#&#8203;14515](getsentry/sentry-javascript#14515))
-   feat(replay): Upgrade rrweb packages to 2.31.0 ([#&#8203;14689](getsentry/sentry-javascript#14689))
-   fix(aws-serverless): Remove v8 layer as it overwrites the current layer for docs ([#&#8203;14679](getsentry/sentry-javascript#14679))
-   fix(browser): Mark stack trace from `captureMessage` with `attachStacktrace: true` as synthetic ([#&#8203;14668](getsentry/sentry-javascript#14668))
-   fix(core): Mark stack trace from `captureMessage` with `attatchStackTrace: true` as synthetic ([#&#8203;14670](getsentry/sentry-javascript#14670))
-   fix(core): Set `level` in server runtime `captureException` ([#&#8203;10587](getsentry/sentry-javascript#10587))
-   fix(profiling-node): Guard invocation of native profiling methods ([#&#8203;14676](getsentry/sentry-javascript#14676))
-   fix(nuxt): Inline nitro-utils function ([#&#8203;14680](getsentry/sentry-javascript#14680))
-   fix(profiling-node): Ensure profileId is added to transaction event ([#&#8203;14681](getsentry/sentry-javascript#14681))
-   fix(react): Add React Router Descendant Routes support ([#&#8203;14304](getsentry/sentry-javascript#14304))
-   fix: Disable ANR and Local Variables if debugger is enabled via CLI args ([#&#8203;14643](getsentry/sentry-javascript#14643))

Work in this release was contributed by [@&#8203;anonrig](https://github.com/anonrig) and [@&#8203;Zih0](https://github.com/Zih0). Thank you for your contributions!

### [`v8.44.0`](https://github.com/getsentry/sentry-javascript/blob/HEAD/CHANGELOG.md#8440)

[Compare Source](getsentry/sentry-javascript@8.43.0...8.44.0)

##### Deprecations

-   **feat: Deprecate `autoSessionTracking` ([#&#8203;14640](getsentry/sentry-javascript#14640

    Deprecates `autoSessionTracking`.
    To enable session tracking, it is recommended to unset `autoSessionTracking` and ensure that either, in browser environments
    the `browserSessionIntegration` is added, or in server environments the `httpIntegration` is added.

    To disable session tracking, it is recommended to unset `autoSessionTracking` and to remove the `browserSessionIntegration` in
    browser environments, or in server environments configure the `httpIntegration` with the `trackIncomingRequestsAsSessions` option set to `false`.

##### Other Changes

-   feat: Reword log message around unsent spans ([#&#8203;14641](getsentry/sentry-javascript#14641))
-   feat(opentelemetry): Set `response` context for http.server spans ([#&#8203;14634](getsentry/sentry-javascript#14634))
-   fix(google-cloud-serverless): Update homepage link in package.json ([#&#8203;14411](getsentry/sentry-javascript#14411))
-   fix(nuxt): Add unbuild config to not fail on warn ([#&#8203;14662](getsentry/sentry-javascript#14662))

Work in this release was contributed by [@&#8203;robinvw1](https://github.com/robinvw1). Thank you for your contribution!

### [`v8.43.0`](https://github.com/getsentry/sentry-javascript/blob/HEAD/CHANGELOG.md#8430)

[Compare Source](getsentry/sentry-javascript@8.42.0...8.43.0)

##### Important Changes

-   **feat(nuxt): Add option autoInjectServerSentry (no default import()) ([#&#8203;14553](getsentry/sentry-javascript#14553

    Using the dynamic `import()` as the default behavior for initializing the SDK on the server-side did not work for every project.
    The default behavior of the SDK has been changed, and you now need to **use the `--import` flag to initialize Sentry on the server-side** to leverage full functionality.

    Example with `--import`:

    ```bash
    node --import ./.output/server/sentry.server.config.mjs .output/server/index.mjs
    ```

    In case you are not able to use the `--import` flag, you can enable auto-injecting Sentry in the `nuxt.config.ts` (comes with limitations):

    ```ts
    sentry: {
      autoInjectServerSentry: 'top-level-import', // or 'experimental_dynamic-import'
    },
    ```

-   **feat(browser): Adds LaunchDarkly and OpenFeature integrations ([#&#8203;14207](getsentry/sentry-javascript#14207

    Adds browser SDK integrations for tracking feature flag evaluations through the LaunchDarkly JS SDK and OpenFeature Web SDK:

    ```ts
    import * as Sentry from '@&#8203;sentry/browser';

    Sentry.init({
      integrations: [
        // Track LaunchDarkly feature flags
        Sentry.launchDarklyIntegration(),
        // Track OpenFeature feature flags
        Sentry.openFeatureIntegration(),
      ],
    });
    ```

    -   Read more about the [Feature Flags](https://develop.sentry.dev/sdk/expected-features/#feature-flags) feature in Sentry.
    -   Read more about the [LaunchDarkly SDK Integration](https://docs.sentry.io/platforms/javascript/configuration/integrations/launchdarkly/).
    -   Read more about the [OpenFeature SDK Integration](https://docs.sentry.io/platforms/javascript/configuration/integrations/openfeature/).

-   **feat(browser): Add `featureFlagsIntegration` for custom tracking of flag evaluations ([#&#8203;14582](getsentry/sentry-javascript#14582

    Adds a browser integration to manually track feature flags with an API. Feature flags are attached to subsequent error events:

    ```ts
    import * as Sentry from '@&#8203;sentry/browser';

    const featureFlagsIntegrationInstance = Sentry.featureFlagsIntegration();

    Sentry.init({
      // Initialize the SDK with the feature flag integration
      integrations: [featureFlagsIntegrationInstance],
    });

    // Manually track a feature flag
    featureFlagsIntegrationInstance.addFeatureFlag('my-feature', true);
    ```

-   **feat(astro): Add Astro 5 support ([#&#8203;14613](getsentry/sentry-javascript#14613

    With this release, the Sentry Astro SDK officially supports Astro 5.

##### Deprecations

-   feat(nextjs): Deprecate typedef for `hideSourceMaps` ([#&#8203;14594](getsentry/sentry-javascript#14594))

    The functionality of `hideSourceMaps` was removed in version 8 but was forgotten to be deprecated and removed.
    It will be completely removed in the next major version.

-   feat(core): Deprecate APIs around `RequestSession`s ([#&#8203;14566](getsentry/sentry-javascript#14566))

    The APIs around `RequestSession`s are mostly used internally.
    Going forward the SDK will not expose concepts around `RequestSession`s.
    Instead, functionality around server-side [Release Health](https://docs.sentry.io/product/releases/health/) will be managed in integrations.

##### Other Changes

-   feat(browser): Add `browserSessionIntegration` ([#&#8203;14551](getsentry/sentry-javascript#14551))
-   feat(core): Add `raw_security` envelope types ([#&#8203;14562](getsentry/sentry-javascript#14562))
-   feat(deps): Bump [@&#8203;opentelemetry/instrumentation](https://github.com/opentelemetry/instrumentation) from 0.55.0 to 0.56.0 ([#&#8203;14625](getsentry/sentry-javascript#14625))
-   feat(deps): Bump [@&#8203;sentry/cli](https://github.com/sentry/cli) from 2.38.2 to 2.39.1 ([#&#8203;14626](getsentry/sentry-javascript#14626))
-   feat(deps): Bump [@&#8203;sentry/rollup-plugin](https://github.com/sentry/rollup-plugin) from 2.22.6 to 2.22.7 ([#&#8203;14622](getsentry/sentry-javascript#14622))
-   feat(deps): Bump [@&#8203;sentry/webpack-plugin](https://github.com/sentry/webpack-plugin) from 2.22.6 to 2.22.7 ([#&#8203;14623](getsentry/sentry-javascript#14623))
-   feat(nestjs): Add fastify support ([#&#8203;14549](getsentry/sentry-javascript#14549))
-   feat(node): Add [@&#8203;vercel/ai](https://github.com/vercel/ai) instrumentation ([#&#8203;13892](getsentry/sentry-javascript#13892))
-   feat(node): Add `disableAnrDetectionForCallback` function ([#&#8203;14359](getsentry/sentry-javascript#14359))
-   feat(node): Add `trackIncomingRequestsAsSessions` option to http integration ([#&#8203;14567](getsentry/sentry-javascript#14567))
-   feat(nuxt): Add option `autoInjectServerSentry` (no default `import()`) ([#&#8203;14553](getsentry/sentry-javascript#14553))
-   feat(nuxt): Add warning when Netlify or Vercel build is discovered ([#&#8203;13868](getsentry/sentry-javascript#13868))
-   feat(nuxt): Improve serverless event flushing and scope isolation ([#&#8203;14605](getsentry/sentry-javascript#14605))
-   feat(opentelemetry): Stop looking at propagation context for span creation ([#&#8203;14481](getsentry/sentry-javascript#14481))
-   feat(opentelemetry): Update OpenTelemetry dependencies to `^1.29.0` ([#&#8203;14590](getsentry/sentry-javascript#14590))
-   feat(opentelemetry): Update OpenTelemetry dependencies to `1.28.0` ([#&#8203;14547](getsentry/sentry-javascript#14547))
-   feat(replay): Upgrade rrweb packages to 2.30.0 ([#&#8203;14597](getsentry/sentry-javascript#14597))
-   fix(core): Decode `filename` and `module` stack frame properties in Node stack parser ([#&#8203;14544](getsentry/sentry-javascript#14544))
-   fix(core): Filter out unactionable CEFSharp promise rejection error by default ([#&#8203;14595](getsentry/sentry-javascript#14595))
-   fix(nextjs): Don't show warning about devtool option ([#&#8203;14552](getsentry/sentry-javascript#14552))
-   fix(nextjs): Only apply tracing metadata to data fetcher data when data is an object ([#&#8203;14575](getsentry/sentry-javascript#14575))
-   fix(node): Guard against invalid `maxSpanWaitDuration` values ([#&#8203;14632](getsentry/sentry-javascript#14632))
-   fix(react): Match routes with `parseSearch` option in TanStack Router instrumentation ([#&#8203;14328](getsentry/sentry-javascript#14328))
-   fix(sveltekit): Fix git SHA not being picked up for release ([#&#8203;14540](getsentry/sentry-javascript#14540))
-   fix(types): Fix generic exports with default ([#&#8203;14576](getsentry/sentry-javascript#14576))

Work in this release was contributed by [@&#8203;lsmurray](https://github.com/lsmurray). Thank you for your contribution!

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

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

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

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

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOS44Mi4wIiwidXBkYXRlZEluVmVyIjoiMzkuODIuMCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOlsiZGVwZW5kZW5jaWVzIl19-->

Reviewed-on: https://git.tristess.app/alexandresoro/ouca/pulls/407
Reviewed-by: Alexandre Soro <code@soro.dev>
Co-authored-by: renovate <renovate@git.tristess.app>
Co-committed-by: renovate <renovate@git.tristess.app>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants